summaryrefslogtreecommitdiff
path: root/sys/dev/pci/ocereg.h
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/pci/ocereg.h')
-rw-r--r--sys/dev/pci/ocereg.h144
1 files changed, 64 insertions, 80 deletions
diff --git a/sys/dev/pci/ocereg.h b/sys/dev/pci/ocereg.h
index 96e78f990e9..57e6d746dc2 100644
--- a/sys/dev/pci/ocereg.h
+++ b/sys/dev/pci/ocereg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: ocereg.h,v 1.2 2012/08/09 19:19:49 mikeb Exp $ */
+/* $OpenBSD: ocereg.h,v 1.3 2012/08/10 16:24:56 mikeb Exp $ */
/*-
* Copyright (C) 2012 Emulex
@@ -38,27 +38,11 @@
* Costa Mesa, CA 92626
*/
-#undef _BIG_ENDIAN /* TODO */
-
-#define OC_CNA_GEN2 0x2
-#define OC_CNA_GEN3 0x3
-#define DEVID_TIGERSHARK 0x700
-#define DEVID_TOMCAT 0x710
-
-#define OCE_DEV_BE2_CFG_BAR 0x14
-#define OCE_DEV_CFG_BAR 0x10
-#define OCE_PCI_CSR_BAR 0x18
-#define OCE_PCI_DB_BAR 0x20
-
-/* PCI CSR offsets */
-#define PCICFG_F1_CSR 0x0 /* F1 for NIC */
-#define PCICFG_SEMAPHORE 0xbc
-#define PCICFG_SOFT_RESET 0x5c
-#define PCICFG_UE_STATUS_HI_MASK 0xac
-#define PCICFG_UE_STATUS_LO_MASK 0xa8
-#define PCICFG_ONLINE0 0xb0
-#define PCICFG_ONLINE1 0xb4
-#define INTR_EN 0x20000000
+#define OCE_BAR_CFG 0x10
+#define OCE_BAR_CFG_BE2 0x14
+#define OCE_BAR_CSR 0x18
+#define OCE_BAR_DB 0x20
+
#define IMAGE_TRANSFER_SIZE (32 * 1024) /* 32K at a time */
/* CSR register offsets */
@@ -219,7 +203,7 @@
typedef union pci_sli_intf_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t sli_valid:3;
uint32_t sli_hint2:5;
uint32_t sli_hint1:8;
@@ -252,7 +236,7 @@ struct phys_addr {
typedef union pcicfg_intr_ctl_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t winselect:2;
uint32_t hostintr:1;
uint32_t pfnum:3;
@@ -273,7 +257,7 @@ typedef union pcicfg_intr_ctl_u {
typedef union pcicfg_semaphore_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t rsvd:31;
uint32_t lock:1;
#else
@@ -286,7 +270,7 @@ typedef union pcicfg_semaphore_u {
typedef union pcicfg_soft_reset_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t nec_ll_rcvdetect:8;
uint32_t dbg_all_reqs_62_49:14;
uint32_t scratchpad0:1;
@@ -307,7 +291,7 @@ typedef union pcicfg_soft_reset_u {
typedef union pcicfg_online1_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t host8_online:1;
uint32_t host7_online:1;
uint32_t host6_online:1;
@@ -360,7 +344,7 @@ typedef union pcicfg_online1_u {
typedef union mpu_ep_semaphore_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t error:1;
uint32_t backup_fw:1;
uint32_t iscsi_no_ip:1;
@@ -385,7 +369,7 @@ typedef union mpu_ep_semaphore_u {
typedef union mpu_ep_control_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t cpu_reset:1;
uint32_t rsvd1:15;
uint32_t ep_ram_init_status:1;
@@ -409,7 +393,7 @@ typedef union mpu_ep_control_u {
typedef union pd_rxulp_db_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t num_posted:8;
uint32_t invalidate:1;
uint32_t rsvd1:13;
@@ -427,7 +411,7 @@ typedef union pd_rxulp_db_u {
typedef union pd_txulp_db_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t rsvd1:2;
uint32_t num_posted:14;
uint32_t rsvd0:6;
@@ -445,7 +429,7 @@ typedef union pd_txulp_db_u {
typedef union cq_db_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t rsvd1:2;
uint32_t rearm:1;
uint32_t num_popped:13;
@@ -467,7 +451,7 @@ typedef union cq_db_u {
typedef union eq_db_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t rsvd1:2;
uint32_t rearm:1;
uint32_t num_popped:13;
@@ -491,7 +475,7 @@ typedef union eq_db_u {
typedef union pd_mpu_mbox_db_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t address:30;
uint32_t hi:1;
uint32_t ready:1;
@@ -507,7 +491,7 @@ typedef union pd_mpu_mbox_db_u {
typedef union pd_mq_db_u {
uint32_t dw0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t rsvd1:2;
uint32_t num_posted:14;
uint32_t rsvd0:5;
@@ -554,7 +538,7 @@ struct oce_mbx_payload {
struct oce_mbx {
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t special:8;
uint32_t rsvd1:16;
uint32_t sge_count:5;
@@ -581,7 +565,7 @@ struct oce_mbx {
struct oce_mq_cqe {
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw0 */
uint32_t extended_status:16;
uint32_t completion_status:16;
@@ -632,7 +616,7 @@ enum MBX_COMPLETION_STATUS {
struct oce_async_cqe_link_state {
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw0 */
uint8_t speed;
uint8_t duplex;
@@ -689,7 +673,7 @@ struct oce_async_event_grp5_pvid_state {
typedef union oce_mq_ext_ctx_u {
uint32_t dw[6];
struct {
- #ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw0 */
uint32_t dw4rsvd1:16;
uint32_t num_pages:16;
@@ -707,7 +691,7 @@ typedef union oce_mq_ext_ctx_u {
uint32_t dw7rsvd1:21;
uint32_t async_cq_id:10;
uint32_t async_cq_valid:1;
- #else
+#else
/* dw0 */
uint32_t num_pages:16;
uint32_t dw4rsvd1:16;
@@ -725,7 +709,7 @@ typedef union oce_mq_ext_ctx_u {
uint32_t async_cq_valid:1;
uint32_t async_cq_id:10;
uint32_t dw7rsvd1:21;
- #endif
+#endif
/* dw5 */
uint32_t dw8rsvd1;
} v0;
@@ -865,7 +849,7 @@ struct mbx_hdr {
union {
uint32_t dw[4];
struct {
- #ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw 0 */
uint32_t domain:8;
uint32_t port_number:8;
@@ -878,7 +862,7 @@ struct mbx_hdr {
/* dw 3 */
uint32_t rsvd0:24;
uint32_t version:8;
- #else
+#else
/* dw 0 */
uint32_t opcode:8;
uint32_t subsystem:8;
@@ -891,10 +875,10 @@ struct mbx_hdr {
/* dw 3 */
uint32_t version:8;
uint32_t rsvd0:24;
- #endif
+#endif
} req;
struct {
- #ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw 0 */
uint32_t domain:8;
uint32_t rsvd0:8;
@@ -904,7 +888,7 @@ struct mbx_hdr {
uint32_t rsvd1:16;
uint32_t additional_status:8;
uint32_t status:8;
- #else
+#else
/* dw 0 */
uint32_t opcode:8;
uint32_t subsystem:8;
@@ -914,7 +898,7 @@ struct mbx_hdr {
uint32_t status:8;
uint32_t additional_status:8;
uint32_t rsvd1:16;
- #endif
+#endif
uint32_t rsp_length;
uint32_t actual_rsp_length;
} rsp;
@@ -954,7 +938,7 @@ struct mbx_set_common_link_speed {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint8_t rsvd0;
uint8_t mac_speed;
uint8_t virtual_port;
@@ -985,7 +969,7 @@ struct mbx_query_common_iface_mac {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint16_t if_id;
uint8_t permanent;
uint8_t type;
@@ -1008,7 +992,7 @@ struct mbx_set_common_iface_mac {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw 0 */
uint16_t if_id;
uint8_t invalidate;
@@ -1056,7 +1040,7 @@ struct mbx_set_common_iface_multicast {
} __packed;
struct qinq_vlan {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint16_t inner;
uint16_t outer;
#else
@@ -1116,7 +1100,7 @@ struct mbx_destroy_common_iface {
/* event queue context structure */
struct oce_eq_ctx {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t dw4rsvd1:16;
uint32_t num_pages:16;
@@ -1178,7 +1162,7 @@ struct mbx_destroy_common_eq {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint16_t rsvd0;
uint16_t id;
#else
@@ -1197,7 +1181,7 @@ struct mbx_destroy_common_eq {
typedef union oce_cq_ctx_u {
uint32_t dw[5];
struct {
- #ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw4 */
uint32_t dw4rsvd1:16;
uint32_t num_pages:16;
@@ -1215,7 +1199,7 @@ typedef union oce_cq_ctx_u {
uint32_t dw6rsvd2:1;
uint32_t eq_id:8;
uint32_t dw6rsvd1:22;
- #else
+#else
/* dw4 */
uint32_t num_pages:16;
uint32_t dw4rsvd1:16;
@@ -1233,14 +1217,14 @@ typedef union oce_cq_ctx_u {
uint32_t eq_id:8;
uint32_t dw6rsvd2:1;
uint32_t armed:1;
- #endif
+#endif
/* dw7 */
uint32_t dw7rsvd1;
/* dw8 */
uint32_t dw8rsvd1;
} v0;
struct {
- #ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw4 */
uint32_t dw4rsvd1:8;
uint32_t page_size:8;
@@ -1262,7 +1246,7 @@ typedef union oce_cq_ctx_u {
/* dw7 */
uint32_t dw7rsvd1:16;
uint32_t cqe_count:16;
- #else
+#else
/* dw4 */
uint32_t num_pages:16;
uint32_t page_size:8;
@@ -1284,7 +1268,7 @@ typedef union oce_cq_ctx_u {
/* dw7 */
uint32_t cqe_count:16;
uint32_t dw7rsvd1:16;
- #endif
+#endif
/* dw8 */
uint32_t dw8rsvd1;
} v2;
@@ -1311,7 +1295,7 @@ struct mbx_destroy_common_cq {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint16_t rsvd0;
uint16_t id;
#else
@@ -1329,7 +1313,7 @@ struct mbx_destroy_common_cq {
typedef union oce_mq_ctx_u {
uint32_t dw[5];
struct {
- #ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw4 */
uint32_t dw4rsvd1:16;
uint32_t num_pages:16;
@@ -1345,7 +1329,7 @@ typedef union oce_mq_ctx_u {
uint32_t dw7rsvd1:21;
uint32_t async_cq_id:10;
uint32_t async_cq_valid:1;
- #else
+#else
/* dw4 */
uint32_t num_pages:16;
uint32_t dw4rsvd1:16;
@@ -1361,7 +1345,7 @@ typedef union oce_mq_ctx_u {
uint32_t async_cq_valid:1;
uint32_t async_cq_id:10;
uint32_t dw7rsvd1:21;
- #endif
+#endif
/* dw8 */
uint32_t dw8rsvd1;
} v0;
@@ -1407,7 +1391,7 @@ struct mbx_destroy_common_mq {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint16_t rsvd0;
uint16_t id;
#else
@@ -1455,7 +1439,7 @@ struct mbx_common_cev_modify_msi_messages {
/* [37] OPCODE_COMMON_GET_FLOW_CONTROL */
struct mbx_common_get_set_flow_control {
struct mbx_hdr hdr;
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint16_t tx_flow_control;
uint16_t rx_flow_control;
#else
@@ -1654,7 +1638,7 @@ struct mbx_common_config_vlan {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint8_t num_vlans;
uint8_t untagged;
uint8_t promisc;
@@ -2093,7 +2077,7 @@ enum RSS_ENABLE_FLAGS {
struct oce_nic_hdr_wqe {
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw0 */
uint32_t rsvd0;
@@ -2173,7 +2157,7 @@ struct oce_nic_frag_wqe {
struct oce_nic_tx_cqe {
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw 0 */
uint32_t status:4;
uint32_t rsvd0:8;
@@ -2236,7 +2220,7 @@ struct oce_nic_rqe {
struct oce_nic_rx_cqe {
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw 0 */
uint32_t ip_options:1;
uint32_t port:1;
@@ -2316,7 +2300,7 @@ struct oce_nic_rx_cqe {
struct oce_nic_rx_cqe_v1 {
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw 0 */
uint32_t ip_options:1;
uint32_t vlan_tag_present:1;
@@ -2340,7 +2324,7 @@ struct oce_nic_rx_cqe_v1 {
/* dw 2 */
uint32_t valid:1;
uint32_t rsvd4:13;
- uint32_t hds_hdr_size:
+ uint32_t hds_hdr_size:2;
uint32_t hds_hdr_frag_index:8;
uint32_t vlantag:1;
uint32_t port:2;
@@ -2398,7 +2382,7 @@ struct mbx_config_nic_promiscuous {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint16_t rsvd0;
uint8_t port1_promisc;
uint8_t port0_promisc;
@@ -2418,7 +2402,7 @@ struct mbx_config_nic_promiscuous {
typedef union oce_wq_ctx_u {
uint32_t dw[17];
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw4 */
uint32_t dw4rsvd2:8;
uint32_t nic_wq_type:8;
@@ -2460,7 +2444,7 @@ typedef union oce_wq_ctx_u {
uint32_t dw8_20rsvd1[13];
} v0;
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw4 */
uint32_t dw4rsvd2:8;
uint32_t nic_wq_type:8;
@@ -2541,7 +2525,7 @@ struct mbx_delete_nic_wq {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw4 */
uint16_t rsvd0;
uint16_t wq_id;
@@ -2585,7 +2569,7 @@ struct mbx_delete_nic_rq {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
/* dw4 */
uint16_t bypass_flush;
uint16_t rq_id;
@@ -2908,7 +2892,7 @@ struct mbx_get_pport_stats {
union {
struct {
/* dw4 */
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t reset_stats:8;
uint32_t rsvd0:8;
uint32_t port_number:16;
@@ -2971,7 +2955,7 @@ struct mbx_get_vport_stats {
union {
struct {
/* dw4 */
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t reset_stats:8;
uint32_t rsvd0:8;
uint32_t vport_number:16;
@@ -3012,7 +2996,7 @@ struct mbx_get_queue_stats {
union {
struct {
/* dw4 */
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t reset_stats:8;
uint32_t queue_type:8;
uint32_t queue_id:16;
@@ -3038,7 +3022,7 @@ struct mbx_config_nic_rss {
struct mbx_hdr hdr;
union {
struct {
-#ifdef _BIG_ENDIAN
+#if _BYTE_ORDER == BIG_ENDIAN
uint32_t if_id;
uint16_t cpu_tbl_sz_log2;
uint16_t enable_rss;