You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

intelxl.h 23KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822
  1. #ifndef _INTELX_H
  2. #define _INTELX_H
  3. /** @file
  4. *
  5. * Intel 40 Gigabit Ethernet network card driver
  6. *
  7. */
  8. FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
  9. #include <stdint.h>
  10. #include <ipxe/if_ether.h>
  11. struct intelxl_nic;
  12. /** BAR size */
  13. #define INTELXL_BAR_SIZE 0x200000
  14. /** Alignment
  15. *
  16. * No data structure requires greater than 128 byte alignment.
  17. */
  18. #define INTELXL_ALIGN 128
  19. /******************************************************************************
  20. *
  21. * Admin queue
  22. *
  23. ******************************************************************************
  24. */
  25. /** PF Admin Command Queue register block */
  26. #define INTELXL_ADMIN_CMD 0x080000
  27. /** PF Admin Event Queue register block */
  28. #define INTELXL_ADMIN_EVT 0x080080
  29. /** Admin Queue Base Address Low Register (offset) */
  30. #define INTELXL_ADMIN_BAL 0x000
  31. /** Admin Queue Base Address High Register (offset) */
  32. #define INTELXL_ADMIN_BAH 0x100
  33. /** Admin Queue Length Register (offset) */
  34. #define INTELXL_ADMIN_LEN 0x200
  35. #define INTELXL_ADMIN_LEN_LEN(x) ( (x) << 0 ) /**< Queue length */
  36. #define INTELXL_ADMIN_LEN_ENABLE 0x80000000UL /**< Queue enable */
  37. /** Admin Queue Head Register (offset) */
  38. #define INTELXL_ADMIN_HEAD 0x300
  39. /** Admin Queue Tail Register (offset) */
  40. #define INTELXL_ADMIN_TAIL 0x400
  41. /** Admin queue register offsets
  42. *
  43. * The physical and virtual function register maps have no discernible
  44. * relationship.
  45. */
  46. struct intelxl_admin_offsets {
  47. /** Base Address Low Register offset */
  48. unsigned int bal;
  49. /** Base Address High Register offset */
  50. unsigned int bah;
  51. /** Length Register offset */
  52. unsigned int len;
  53. /** Head Register offset */
  54. unsigned int head;
  55. /** Tail Register offset */
  56. unsigned int tail;
  57. };
  58. /** Admin queue data buffer command parameters */
  59. struct intelxl_admin_buffer_params {
  60. /** Reserved */
  61. uint8_t reserved[8];
  62. /** Buffer address high */
  63. uint32_t high;
  64. /** Buffer address low */
  65. uint32_t low;
  66. } __attribute__ (( packed ));
  67. /** Admin queue Get Version command */
  68. #define INTELXL_ADMIN_VERSION 0x0001
  69. /** Admin queue version number */
  70. struct intelxl_admin_version {
  71. /** Major version number */
  72. uint16_t major;
  73. /** Minor version number */
  74. uint16_t minor;
  75. } __attribute__ (( packed ));
  76. /** Admin queue Get Version command parameters */
  77. struct intelxl_admin_version_params {
  78. /** ROM version */
  79. uint32_t rom;
  80. /** Firmware build ID */
  81. uint32_t build;
  82. /** Firmware version */
  83. struct intelxl_admin_version firmware;
  84. /** API version */
  85. struct intelxl_admin_version api;
  86. } __attribute__ (( packed ));
  87. /** Admin queue Driver Version command */
  88. #define INTELXL_ADMIN_DRIVER 0x0002
  89. /** Admin queue Driver Version command parameters */
  90. struct intelxl_admin_driver_params {
  91. /** Driver version */
  92. uint8_t major;
  93. /** Minor version */
  94. uint8_t minor;
  95. /** Build version */
  96. uint8_t build;
  97. /** Sub-build version */
  98. uint8_t sub;
  99. /** Reserved */
  100. uint8_t reserved[4];
  101. /** Data buffer address */
  102. uint64_t address;
  103. } __attribute__ (( packed ));
  104. /** Admin queue Driver Version data buffer */
  105. struct intelxl_admin_driver_buffer {
  106. /** Driver name */
  107. char name[32];
  108. } __attribute__ (( packed ));
  109. /** Admin queue Shutdown command */
  110. #define INTELXL_ADMIN_SHUTDOWN 0x0003
  111. /** Admin queue Shutdown command parameters */
  112. struct intelxl_admin_shutdown_params {
  113. /** Driver unloading */
  114. uint8_t unloading;
  115. /** Reserved */
  116. uint8_t reserved[15];
  117. } __attribute__ (( packed ));
  118. /** Driver is unloading */
  119. #define INTELXL_ADMIN_SHUTDOWN_UNLOADING 0x01
  120. /** Admin queue Get Switch Configuration command */
  121. #define INTELXL_ADMIN_SWITCH 0x0200
  122. /** Switching element configuration */
  123. struct intelxl_admin_switch_config {
  124. /** Switching element type */
  125. uint8_t type;
  126. /** Revision */
  127. uint8_t revision;
  128. /** Switching element ID */
  129. uint16_t seid;
  130. /** Uplink switching element ID */
  131. uint16_t uplink;
  132. /** Downlink switching element ID */
  133. uint16_t downlink;
  134. /** Reserved */
  135. uint8_t reserved_b[3];
  136. /** Connection type */
  137. uint8_t connection;
  138. /** Reserved */
  139. uint8_t reserved_c[2];
  140. /** Element specific information */
  141. uint16_t info;
  142. } __attribute__ (( packed ));
  143. /** Virtual Station Inferface element type */
  144. #define INTELXL_ADMIN_SWITCH_TYPE_VSI 19
  145. /** Admin queue Get Switch Configuration command parameters */
  146. struct intelxl_admin_switch_params {
  147. /** Starting switching element identifier */
  148. uint16_t next;
  149. /** Reserved */
  150. uint8_t reserved[6];
  151. /** Data buffer address */
  152. uint64_t address;
  153. } __attribute__ (( packed ));
  154. /** Admin queue Get Switch Configuration data buffer */
  155. struct intelxl_admin_switch_buffer {
  156. /** Number of switching elements reported */
  157. uint16_t count;
  158. /** Total number of switching elements */
  159. uint16_t total;
  160. /** Reserved */
  161. uint8_t reserved_a[12];
  162. /** Switch configuration */
  163. struct intelxl_admin_switch_config cfg;
  164. } __attribute__ (( packed ));
  165. /** Admin queue Get VSI Parameters command */
  166. #define INTELXL_ADMIN_VSI 0x0212
  167. /** Admin queue Get VSI Parameters command parameters */
  168. struct intelxl_admin_vsi_params {
  169. /** VSI switching element ID */
  170. uint16_t vsi;
  171. /** Reserved */
  172. uint8_t reserved[6];
  173. /** Data buffer address */
  174. uint64_t address;
  175. } __attribute__ (( packed ));
  176. /** Admin queue Get VSI Parameters data buffer */
  177. struct intelxl_admin_vsi_buffer {
  178. /** Reserved */
  179. uint8_t reserved_a[30];
  180. /** Queue numbers */
  181. uint16_t queue[16];
  182. /** Reserved */
  183. uint8_t reserved_b[34];
  184. /** Queue set handles for each traffic class */
  185. uint16_t qset[8];
  186. /** Reserved */
  187. uint8_t reserved_c[16];
  188. } __attribute__ (( packed ));
  189. /** Admin queue Set VSI Promiscuous Modes command */
  190. #define INTELXL_ADMIN_PROMISC 0x0254
  191. /** Admin queue Set VSI Promiscuous Modes command parameters */
  192. struct intelxl_admin_promisc_params {
  193. /** Flags */
  194. uint16_t flags;
  195. /** Valid flags */
  196. uint16_t valid;
  197. /** VSI switching element ID */
  198. uint16_t vsi;
  199. /** Reserved */
  200. uint8_t reserved[10];
  201. } __attribute__ (( packed ));
  202. /** Promiscuous unicast mode */
  203. #define INTELXL_ADMIN_PROMISC_FL_UNICAST 0x0001
  204. /** Promiscuous multicast mode */
  205. #define INTELXL_ADMIN_PROMISC_FL_MULTICAST 0x0002
  206. /** Promiscuous broadcast mode */
  207. #define INTELXL_ADMIN_PROMISC_FL_BROADCAST 0x0004
  208. /** Promiscuous VLAN mode */
  209. #define INTELXL_ADMIN_PROMISC_FL_VLAN 0x0010
  210. /** Admin queue Restart Autonegotiation command */
  211. #define INTELXL_ADMIN_AUTONEG 0x0605
  212. /** Admin queue Restart Autonegotiation command parameters */
  213. struct intelxl_admin_autoneg_params {
  214. /** Flags */
  215. uint8_t flags;
  216. /** Reserved */
  217. uint8_t reserved[15];
  218. } __attribute__ (( packed ));
  219. /** Restart autonegotiation */
  220. #define INTELXL_ADMIN_AUTONEG_FL_RESTART 0x02
  221. /** Enable link */
  222. #define INTELXL_ADMIN_AUTONEG_FL_ENABLE 0x04
  223. /** Admin queue Get Link Status command */
  224. #define INTELXL_ADMIN_LINK 0x0607
  225. /** Admin queue Get Link Status command parameters */
  226. struct intelxl_admin_link_params {
  227. /** Link status notification */
  228. uint8_t notify;
  229. /** Reserved */
  230. uint8_t reserved_a;
  231. /** PHY type */
  232. uint8_t phy;
  233. /** Link speed */
  234. uint8_t speed;
  235. /** Link status */
  236. uint8_t status;
  237. /** Reserved */
  238. uint8_t reserved_b[11];
  239. } __attribute__ (( packed ));
  240. /** Notify driver of link status changes */
  241. #define INTELXL_ADMIN_LINK_NOTIFY 0x03
  242. /** Link is up */
  243. #define INTELXL_ADMIN_LINK_UP 0x01
  244. /** Admin queue command parameters */
  245. union intelxl_admin_params {
  246. /** Additional data buffer command parameters */
  247. struct intelxl_admin_buffer_params buffer;
  248. /** Get Version command parameters */
  249. struct intelxl_admin_version_params version;
  250. /** Driver Version command parameters */
  251. struct intelxl_admin_driver_params driver;
  252. /** Shutdown command parameters */
  253. struct intelxl_admin_shutdown_params shutdown;
  254. /** Get Switch Configuration command parameters */
  255. struct intelxl_admin_switch_params sw;
  256. /** Get VSI Parameters command parameters */
  257. struct intelxl_admin_vsi_params vsi;
  258. /** Set VSI Promiscuous Modes command parameters */
  259. struct intelxl_admin_promisc_params promisc;
  260. /** Restart Autonegotiation command parameters */
  261. struct intelxl_admin_autoneg_params autoneg;
  262. /** Get Link Status command parameters */
  263. struct intelxl_admin_link_params link;
  264. } __attribute__ (( packed ));
  265. /** Admin queue data buffer */
  266. union intelxl_admin_buffer {
  267. /** Driver Version data buffer */
  268. struct intelxl_admin_driver_buffer driver;
  269. /** Get Switch Configuration data buffer */
  270. struct intelxl_admin_switch_buffer sw;
  271. /** Get VSI Parameters data buffer */
  272. struct intelxl_admin_vsi_buffer vsi;
  273. /** Alignment padding */
  274. uint8_t pad[INTELXL_ALIGN];
  275. } __attribute__ (( packed ));
  276. /** Admin queue descriptor */
  277. struct intelxl_admin_descriptor {
  278. /** Flags */
  279. uint16_t flags;
  280. /** Opcode */
  281. uint16_t opcode;
  282. /** Data length */
  283. uint16_t len;
  284. /** Return value */
  285. uint16_t ret;
  286. /** Cookie */
  287. uint32_t cookie;
  288. /** Reserved */
  289. uint32_t reserved;
  290. /** Parameters */
  291. union intelxl_admin_params params;
  292. } __attribute__ (( packed ));
  293. /** Admin descriptor done */
  294. #define INTELXL_ADMIN_FL_DD 0x0001
  295. /** Admin descriptor contains a completion */
  296. #define INTELXL_ADMIN_FL_CMP 0x0002
  297. /** Admin descriptor completed in error */
  298. #define INTELXL_ADMIN_FL_ERR 0x0004
  299. /** Admin descriptor uses data buffer for command parameters */
  300. #define INTELXL_ADMIN_FL_RD 0x0400
  301. /** Admin descriptor uses data buffer */
  302. #define INTELXL_ADMIN_FL_BUF 0x1000
  303. /** Admin queue */
  304. struct intelxl_admin {
  305. /** Descriptors */
  306. struct intelxl_admin_descriptor *desc;
  307. /** Data buffers */
  308. union intelxl_admin_buffer *buf;
  309. /** Queue index */
  310. unsigned int index;
  311. /** Register block base */
  312. unsigned int base;
  313. /** Register offsets */
  314. const struct intelxl_admin_offsets *regs;
  315. };
  316. /**
  317. * Initialise admin queue
  318. *
  319. * @v admin Admin queue
  320. * @v base Register block base
  321. * @v regs Register offsets
  322. */
  323. static inline __attribute__ (( always_inline )) void
  324. intelxl_init_admin ( struct intelxl_admin *admin, unsigned int base,
  325. const struct intelxl_admin_offsets *regs ) {
  326. admin->base = base;
  327. admin->regs = regs;
  328. }
  329. /** Number of admin queue descriptors */
  330. #define INTELXL_ADMIN_NUM_DESC 4
  331. /** Maximum time to wait for an admin request to complete */
  332. #define INTELXL_ADMIN_MAX_WAIT_MS 100
  333. /** Admin queue API major version */
  334. #define INTELXL_ADMIN_API_MAJOR 1
  335. /******************************************************************************
  336. *
  337. * Transmit and receive queue context
  338. *
  339. ******************************************************************************
  340. */
  341. /** CMLAN Context Data Register */
  342. #define INTELXL_PFCM_LANCTXDATA(x) ( 0x10c100 + ( 0x80 * (x) ) )
  343. /** CMLAN Context Control Register */
  344. #define INTELXL_PFCM_LANCTXCTL 0x10c300
  345. #define INTELXL_PFCM_LANCTXCTL_QUEUE_NUM(x) \
  346. ( (x) << 0 ) /**< Queue number */
  347. #define INTELXL_PFCM_LANCTXCTL_SUB_LINE(x) \
  348. ( (x) << 12 ) /**< Sub-line */
  349. #define INTELXL_PFCM_LANCTXCTL_TYPE(x) \
  350. ( (x) << 15 ) /**< Queue type */
  351. #define INTELXL_PFCM_LANCTXCTL_TYPE_RX \
  352. INTELXL_PFCM_LANCTXCTL_TYPE ( 0x0 ) /**< RX queue type */
  353. #define INTELXL_PFCM_LANCTXCTL_TYPE_TX \
  354. INTELXL_PFCM_LANCTXCTL_TYPE ( 0x1 ) /**< TX queue type */
  355. #define INTELXL_PFCM_LANCTXCTL_OP_CODE(x) \
  356. ( (x) << 17 ) /**< Op code */
  357. #define INTELXL_PFCM_LANCTXCTL_OP_CODE_READ \
  358. INTELXL_PFCM_LANCTXCTL_OP_CODE ( 0x0 ) /**< Read context */
  359. #define INTELXL_PFCM_LANCTXCTL_OP_CODE_WRITE \
  360. INTELXL_PFCM_LANCTXCTL_OP_CODE ( 0x1 ) /**< Write context */
  361. /** CMLAN Context Status Register */
  362. #define INTELXL_PFCM_LANCTXSTAT 0x10c380
  363. #define INTELXL_PFCM_LANCTXSTAT_DONE 0x00000001UL /**< Complete */
  364. /** Queue context line */
  365. struct intelxl_context_line {
  366. /** Raw data */
  367. uint32_t raw[4];
  368. } __attribute__ (( packed ));
  369. /** Transmit queue context */
  370. struct intelxl_context_tx {
  371. /** Head pointer */
  372. uint16_t head;
  373. /** Flags */
  374. uint16_t flags;
  375. /** Base address */
  376. uint64_t base;
  377. /** Reserved */
  378. uint8_t reserved_a[8];
  379. /** Queue count */
  380. uint16_t count;
  381. /** Reserved */
  382. uint8_t reserved_b[100];
  383. /** Queue set */
  384. uint16_t qset;
  385. /** Reserved */
  386. uint8_t reserved_c[4];
  387. } __attribute__ (( packed ));
  388. /** New transmit queue context */
  389. #define INTELXL_CTX_TX_FL_NEW 0x4000
  390. /** Transmit queue base address */
  391. #define INTELXL_CTX_TX_BASE( base ) ( (base) >> 7 )
  392. /** Transmit queue count */
  393. #define INTELXL_CTX_TX_COUNT( count ) ( (count) << 1 )
  394. /** Transmit queue set */
  395. #define INTELXL_CTX_TX_QSET( qset) ( (qset) << 4 )
  396. /** Receive queue context */
  397. struct intelxl_context_rx {
  398. /** Head pointer */
  399. uint16_t head;
  400. /** Reserved */
  401. uint8_t reserved_a[2];
  402. /** Base address and queue count */
  403. uint64_t base_count;
  404. /** Data buffer length */
  405. uint16_t len;
  406. /** Flags */
  407. uint8_t flags;
  408. /** Reserved */
  409. uint8_t reserved_b[7];
  410. /** Maximum frame size */
  411. uint16_t mfs;
  412. } __attribute__ (( packed ));
  413. /** Receive queue base address and queue count */
  414. #define INTELXL_CTX_RX_BASE_COUNT( base, count ) \
  415. ( ( (base) >> 7 ) | ( ( ( uint64_t ) (count) ) << 57 ) )
  416. /** Receive queue data buffer length */
  417. #define INTELXL_CTX_RX_LEN( len ) ( (len) >> 1 )
  418. /** Strip CRC from received packets */
  419. #define INTELXL_CTX_RX_FL_CRCSTRIP 0x20
  420. /** Receive queue maximum frame size */
  421. #define INTELXL_CTX_RX_MFS( mfs ) ( (mfs) >> 2 )
  422. /** Maximum time to wait for a context operation to complete */
  423. #define INTELXL_CTX_MAX_WAIT_MS 100
  424. /** Time to wait for a queue to become enabled */
  425. #define INTELXL_QUEUE_ENABLE_DELAY_US 20
  426. /** Time to wait for a transmit queue to become pre-disabled */
  427. #define INTELXL_QUEUE_PRE_DISABLE_DELAY_US 400
  428. /** Maximum time to wait for a queue to become disabled */
  429. #define INTELXL_QUEUE_DISABLE_MAX_WAIT_MS 1000
  430. /******************************************************************************
  431. *
  432. * Transmit and receive descriptors
  433. *
  434. ******************************************************************************
  435. */
  436. /** Global Transmit Queue Head register */
  437. #define INTELXL_QTX_HEAD(x) ( 0x0e4000 + ( 0x4 * (x) ) )
  438. /** Global Transmit Pre Queue Disable register */
  439. #define INTELXL_GLLAN_TXPRE_QDIS(x) ( 0x0e6500 + ( 0x4 * ( (x) / 0x80 ) ) )
  440. #define INTELXL_GLLAN_TXPRE_QDIS_QINDX(x) \
  441. ( (x) << 0 ) /**< Queue index */
  442. #define INTELXL_GLLAN_TXPRE_QDIS_SET_QDIS \
  443. 0x40000000UL /**< Set disable */
  444. #define INTELXL_GLLAN_TXPRE_QDIS_CLEAR_QDIS \
  445. 0x80000000UL /**< Clear disable */
  446. /** Global Transmit Queue register block */
  447. #define INTELXL_QTX(x) ( 0x100000 + ( 0x4 * (x) ) )
  448. /** Global Receive Queue register block */
  449. #define INTELXL_QRX(x) ( 0x120000 + ( 0x4 * (x) ) )
  450. /** Queue Enable Register (offset) */
  451. #define INTELXL_QXX_ENA 0x0000
  452. #define INTELXL_QXX_ENA_REQ 0x00000001UL /**< Enable request */
  453. #define INTELXL_QXX_ENA_STAT 0x00000004UL /**< Enabled status */
  454. /** Queue Control Register (offset) */
  455. #define INTELXL_QXX_CTL 0x4000
  456. #define INTELXL_QXX_CTL_PFVF_Q(x) ( (x) << 0 ) /**< PF/VF queue */
  457. #define INTELXL_QXX_CTL_PFVF_Q_PF \
  458. INTELXL_QXX_CTL_PFVF_Q ( 0x2 ) /**< PF queue */
  459. #define INTELXL_QXX_CTL_PFVF_PF_INDX(x) ( (x) << 2 ) /**< PF index */
  460. /** Queue Tail Pointer Register (offset) */
  461. #define INTELXL_QXX_TAIL 0x8000
  462. /** Transmit data descriptor */
  463. struct intelxl_tx_data_descriptor {
  464. /** Buffer address */
  465. uint64_t address;
  466. /** Flags */
  467. uint32_t flags;
  468. /** Length */
  469. uint32_t len;
  470. } __attribute__ (( packed ));
  471. /** Transmit data descriptor type */
  472. #define INTELXL_TX_DATA_DTYP 0x0
  473. /** Transmit data descriptor end of packet */
  474. #define INTELXL_TX_DATA_EOP 0x10
  475. /** Transmit data descriptor report status */
  476. #define INTELXL_TX_DATA_RS 0x20
  477. /** Transmit data descriptor pretty please
  478. *
  479. * This bit is completely missing from older versions of the XL710
  480. * datasheet. Later versions describe it innocuously as "reserved,
  481. * must be 1". Without this bit, everything will appear to work (up
  482. * to and including the port "transmit good octets" counter), but no
  483. * packet will actually be sent.
  484. */
  485. #define INTELXL_TX_DATA_JFDI 0x40
  486. /** Transmit data descriptor length */
  487. #define INTELXL_TX_DATA_LEN( len ) ( (len) << 2 )
  488. /** Transmit writeback descriptor */
  489. struct intelxl_tx_writeback_descriptor {
  490. /** Reserved */
  491. uint8_t reserved_a[8];
  492. /** Flags */
  493. uint8_t flags;
  494. /** Reserved */
  495. uint8_t reserved_b[7];
  496. } __attribute__ (( packed ));
  497. /** Transmit writeback descriptor complete */
  498. #define INTELXL_TX_WB_FL_DD 0x01
  499. /** Receive data descriptor */
  500. struct intelxl_rx_data_descriptor {
  501. /** Buffer address */
  502. uint64_t address;
  503. /** Flags */
  504. uint32_t flags;
  505. /** Reserved */
  506. uint8_t reserved[4];
  507. } __attribute__ (( packed ));
  508. /** Receive writeback descriptor */
  509. struct intelxl_rx_writeback_descriptor {
  510. /** Reserved */
  511. uint8_t reserved_a[2];
  512. /** VLAN tag */
  513. uint16_t vlan;
  514. /** Reserved */
  515. uint8_t reserved_b[4];
  516. /** Flags */
  517. uint32_t flags;
  518. /** Length */
  519. uint32_t len;
  520. } __attribute__ (( packed ));
  521. /** Receive writeback descriptor complete */
  522. #define INTELXL_RX_WB_FL_DD 0x00000001UL
  523. /** Receive writeback descriptor VLAN tag present */
  524. #define INTELXL_RX_WB_FL_VLAN 0x00000004UL
  525. /** Receive writeback descriptor error */
  526. #define INTELXL_RX_WB_FL_RXE 0x00080000UL
  527. /** Receive writeback descriptor length */
  528. #define INTELXL_RX_WB_LEN(len) ( ( (len) >> 6 ) & 0x3fff )
  529. /** Packet descriptor */
  530. union intelxl_descriptor {
  531. /** Transmit data descriptor */
  532. struct intelxl_tx_data_descriptor tx;
  533. /** Transmit writeback descriptor */
  534. struct intelxl_tx_writeback_descriptor tx_wb;
  535. /** Receive data descriptor */
  536. struct intelxl_rx_data_descriptor rx;
  537. /** Receive writeback descriptor */
  538. struct intelxl_rx_writeback_descriptor rx_wb;
  539. };
  540. /** Descriptor ring */
  541. struct intelxl_ring {
  542. /** Descriptors */
  543. union intelxl_descriptor *desc;
  544. /** Producer index */
  545. unsigned int prod;
  546. /** Consumer index */
  547. unsigned int cons;
  548. /** Register block */
  549. unsigned int reg;
  550. /** Length (in bytes) */
  551. size_t len;
  552. /** Program queue context
  553. *
  554. * @v intelxl Intel device
  555. * @v address Descriptor ring base address
  556. */
  557. int ( * context ) ( struct intelxl_nic *intelxl, physaddr_t address );
  558. };
  559. /**
  560. * Initialise descriptor ring
  561. *
  562. * @v ring Descriptor ring
  563. * @v count Number of descriptors
  564. * @v context Method to program queue context
  565. */
  566. static inline __attribute__ (( always_inline)) void
  567. intelxl_init_ring ( struct intelxl_ring *ring, unsigned int count,
  568. int ( * context ) ( struct intelxl_nic *intelxl,
  569. physaddr_t address ) ) {
  570. ring->len = ( count * sizeof ( ring->desc[0] ) );
  571. ring->context = context;
  572. }
  573. /** Number of transmit descriptors */
  574. #define INTELXL_TX_NUM_DESC 16
  575. /** Transmit descriptor ring maximum fill level */
  576. #define INTELXL_TX_FILL ( INTELXL_TX_NUM_DESC - 1 )
  577. /** Number of receive descriptors
  578. *
  579. * In PXE mode (i.e. able to post single receive descriptors), 8
  580. * descriptors is the only permitted value covering all possible
  581. * numbers of PFs.
  582. */
  583. #define INTELXL_RX_NUM_DESC 8
  584. /** Receive descriptor ring fill level */
  585. #define INTELXL_RX_FILL ( INTELXL_RX_NUM_DESC - 1 )
  586. /******************************************************************************
  587. *
  588. * Top level
  589. *
  590. ******************************************************************************
  591. */
  592. /** PF Interrupt Zero Dynamic Control Register */
  593. #define INTELXL_PFINT_DYN_CTL0 0x038480
  594. #define INTELXL_PFINT_DYN_CTL0_INTENA 0x00000001UL /**< Enable */
  595. #define INTELXL_PFINT_DYN_CTL0_CLEARPBA 0x00000002UL /**< Acknowledge */
  596. #define INTELXL_PFINT_DYN_CTL0_INTENA_MASK 0x80000000UL /**< Ignore enable */
  597. /** PF Interrupt Zero Linked List Register */
  598. #define INTELXL_PFINT_LNKLST0 0x038500
  599. #define INTELXL_PFINT_LNKLST0_FIRSTQ_INDX(x) \
  600. ( (x) << 0 ) /**< Queue index */
  601. #define INTELXL_PFINT_LNKLST0_FIRSTQ_INDX_NONE \
  602. INTELXL_PFINT_LNKLST0_FIRSTQ_INDX ( 0x7ff ) /**< End of list */
  603. #define INTELXL_PFINT_LNKLST0_FIRSTQ_TYPE(x) \
  604. ( (x) << 11 ) /**< Queue type */
  605. #define INTELXL_PFINT_LNKLST0_FIRSTQ_TYPE_RX \
  606. INTELXL_PFINT_LNKLST0_FIRSTQ_TYPE ( 0x0 ) /**< Receive queue */
  607. #define INTELXL_PFINT_LNKLST0_FIRSTQ_TYPE_TX \
  608. INTELXL_PFINT_LNKLST0_FIRSTQ_TYPE ( 0x1 ) /**< Transmit queue */
  609. /** PF Interrupt Zero Cause Enablement Register */
  610. #define INTELXL_PFINT_ICR0_ENA 0x038800
  611. #define INTELXL_PFINT_ICR0_ENA_ADMINQ 0x40000000UL /**< Admin event */
  612. /** Receive Queue Interrupt Cause Control Register */
  613. #define INTELXL_QINT_RQCTL(x) ( 0x03a000 + ( 0x4 * (x) ) )
  614. #define INTELXL_QINT_RQCTL_NEXTQ_INDX(x) ( (x) << 16 ) /**< Queue index */
  615. #define INTELXL_QINT_RQCTL_NEXTQ_INDX_NONE \
  616. INTELXL_QINT_RQCTL_NEXTQ_INDX ( 0x7ff ) /**< End of list */
  617. #define INTELXL_QINT_RQCTL_NEXTQ_TYPE(x) ( (x) << 27 ) /**< Queue type */
  618. #define INTELXL_QINT_RQCTL_NEXTQ_TYPE_RX \
  619. INTELXL_QINT_RQCTL_NEXTQ_TYPE ( 0x0 ) /**< Receive queue */
  620. #define INTELXL_QINT_RQCTL_NEXTQ_TYPE_TX \
  621. INTELXL_QINT_RQCTL_NEXTQ_TYPE ( 0x1 ) /**< Transmit queue */
  622. #define INTELXL_QINT_RQCTL_CAUSE_ENA 0x40000000UL /**< Enable */
  623. /** Transmit Queue Interrupt Cause Control Register */
  624. #define INTELXL_QINT_TQCTL(x) ( 0x03c000 + ( 0x4 * (x) ) )
  625. #define INTELXL_QINT_TQCTL_NEXTQ_INDX(x) ( (x) << 16 ) /**< Queue index */
  626. #define INTELXL_QINT_TQCTL_NEXTQ_INDX_NONE \
  627. INTELXL_QINT_TQCTL_NEXTQ_INDX ( 0x7ff ) /**< End of list */
  628. #define INTELXL_QINT_TQCTL_NEXTQ_TYPE(x) ( (x) << 27 ) /**< Queue type */
  629. #define INTELXL_QINT_TQCTL_NEXTQ_TYPE_RX \
  630. INTELXL_QINT_TQCTL_NEXTQ_TYPE ( 0x0 ) /**< Receive queue */
  631. #define INTELXL_QINT_TQCTL_NEXTQ_TYPE_TX \
  632. INTELXL_QINT_TQCTL_NEXTQ_TYPE ( 0x1 ) /**< Transmit queue */
  633. #define INTELXL_QINT_TQCTL_CAUSE_ENA 0x40000000UL /**< Enable */
  634. /** PF Control Register */
  635. #define INTELXL_PFGEN_CTRL 0x092400
  636. #define INTELXL_PFGEN_CTRL_PFSWR 0x00000001UL /**< Software Reset */
  637. /** Time to delay for device reset, in milliseconds */
  638. #define INTELXL_RESET_DELAY_MS 100
  639. /** PF Queue Allocation Register */
  640. #define INTELXL_PFLAN_QALLOC 0x1c0400
  641. #define INTELXL_PFLAN_QALLOC_FIRSTQ(x) \
  642. ( ( (x) >> 0 ) & 0x7ff ) /**< First queue */
  643. #define INTELXL_PFLAN_QALLOC_LASTQ(x) \
  644. ( ( (x) >> 16 ) & 0x7ff ) /**< Last queue */
  645. /** PF LAN Port Number Register */
  646. #define INTELXL_PFGEN_PORTNUM 0x1c0480
  647. #define INTELXL_PFGEN_PORTNUM_PORT_NUM(x) \
  648. ( ( (x) >> 0 ) & 0x3 ) /**< Port number */
  649. /** Port MAC Address Low Register */
  650. #define INTELXL_PRTGL_SAL 0x1e2120
  651. /** Port MAC Address High Register */
  652. #define INTELXL_PRTGL_SAH 0x1e2140
  653. #define INTELXL_PRTGL_SAH_MFS_GET(x) ( (x) >> 16 ) /**< Max frame size */
  654. #define INTELXL_PRTGL_SAH_MFS_SET(x) ( (x) << 16 ) /**< Max frame size */
  655. /** Receive address */
  656. union intelxl_receive_address {
  657. struct {
  658. uint32_t low;
  659. uint32_t high;
  660. } __attribute__ (( packed )) reg;
  661. uint8_t raw[ETH_ALEN];
  662. };
  663. /** An Intel 40Gigabit network card */
  664. struct intelxl_nic {
  665. /** Registers */
  666. void *regs;
  667. /** Maximum frame size */
  668. size_t mfs;
  669. /** Physical function number */
  670. unsigned int pf;
  671. /** Absolute queue number base */
  672. unsigned int base;
  673. /** Port number */
  674. unsigned int port;
  675. /** Queue number */
  676. unsigned int queue;
  677. /** Virtual Station Interface switching element ID */
  678. unsigned int vsi;
  679. /** Queue set handle */
  680. unsigned int qset;
  681. /** Admin command queue */
  682. struct intelxl_admin command;
  683. /** Admin event queue */
  684. struct intelxl_admin event;
  685. /** Transmit descriptor ring */
  686. struct intelxl_ring tx;
  687. /** Receive descriptor ring */
  688. struct intelxl_ring rx;
  689. /** Receive I/O buffers */
  690. struct io_buffer *rx_iobuf[INTELXL_RX_NUM_DESC];
  691. };
  692. #endif /* _INTELXL_H */