mirror of
https://github.com/AuxXxilium/synology-igc.git
synced 2024-11-23 23:11:07 +07:00
31 lines
909 B
C
31 lines
909 B
C
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
/* Copyright (c) 2020 Intel Corporation */
|
||
|
|
||
|
bool igc_reg_test(struct igc_adapter *adapter, u64 *data);
|
||
|
bool igc_eeprom_test(struct igc_adapter *adapter, u64 *data);
|
||
|
bool igc_link_test(struct igc_adapter *adapter, u64 *data);
|
||
|
|
||
|
struct igc_reg_test {
|
||
|
u16 reg;
|
||
|
u8 array_len;
|
||
|
u8 test_type;
|
||
|
u32 mask;
|
||
|
u32 write;
|
||
|
};
|
||
|
|
||
|
/* In the hardware, registers are laid out either singly, in arrays
|
||
|
* spaced 0x40 bytes apart, or in contiguous tables. We assume
|
||
|
* most tests take place on arrays or single registers (handled
|
||
|
* as a single-element array) and special-case the tables.
|
||
|
* Table tests are always pattern tests.
|
||
|
*
|
||
|
* We also make provision for some required setup steps by specifying
|
||
|
* registers to be written without any read-back testing.
|
||
|
*/
|
||
|
|
||
|
#define PATTERN_TEST 1
|
||
|
#define SET_READ_TEST 2
|
||
|
#define TABLE32_TEST 3
|
||
|
#define TABLE64_TEST_LO 4
|
||
|
#define TABLE64_TEST_HI 5
|