summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/pv/if_hvn.c244
-rw-r--r--sys/dev/pv/rndisreg.h825
2 files changed, 134 insertions, 935 deletions
diff --git a/sys/dev/pv/if_hvn.c b/sys/dev/pv/if_hvn.c
index 5a6e6525233..bb121843476 100644
--- a/sys/dev/pv/if_hvn.c
+++ b/sys/dev/pv/if_hvn.c
@@ -55,6 +55,8 @@
#include <dev/pv/hypervreg.h>
#include <dev/pv/hypervvar.h>
+
+#include <dev/rndis.h>
#include <dev/pv/rndisreg.h>
#include <dev/pv/if_hvnreg.h>
@@ -84,15 +86,18 @@
#define HVN_RNDIS_CMPBUFSZ 512
#define HVN_RNDIS_MSG_LEN \
- (sizeof(struct rndis) + RNDIS_VLAN_PPI_SIZE + RNDIS_CSUM_PPI_SIZE)
+ (sizeof(struct rndis_packet_msg) + RNDIS_VLAN_PPI_SIZE + \
+ RNDIS_CSUM_PPI_SIZE)
struct rndis_cmd {
uint32_t rc_id;
struct hvn_nvs_rndis rc_msg;
- struct rndis *rc_req;
+ void *rc_req;
bus_dmamap_t rc_dmap;
+ bus_dma_segment_t rc_segs;
+ int rc_nsegs;
uint64_t rc_gpa;
- struct rndis rc_cmp;
+ struct rndis_packet_msg rc_cmp;
uint32_t rc_cmplen;
uint8_t rc_cmpbuf[HVN_RNDIS_CMPBUFSZ];
struct mutex rc_mtx;
@@ -117,7 +122,7 @@ struct hvn_tx_desc {
bus_dmamap_t txd_dmap;
struct vmbus_gpa txd_gpa;
struct hvn_nvs_rndis txd_cmd;
- struct rndis *txd_req;
+ struct rndis_packet_msg *txd_req;
};
struct hvn_softc {
@@ -175,7 +180,6 @@ void hvn_start(struct ifnet *);
int hvn_encap(struct hvn_softc *, struct mbuf *, struct hvn_tx_desc **);
void hvn_decap(struct hvn_softc *, struct hvn_tx_desc *);
void hvn_txeof(struct hvn_softc *, uint64_t);
-void hvn_rxeof(struct hvn_softc *, void *);
int hvn_rx_ring_create(struct hvn_softc *);
int hvn_rx_ring_destroy(struct hvn_softc *);
int hvn_tx_ring_create(struct hvn_softc *);
@@ -195,9 +199,8 @@ void hvn_nvs_detach(struct hvn_softc *);
/* RNDIS */
int hvn_rndis_attach(struct hvn_softc *);
int hvn_rndis_cmd(struct hvn_softc *, struct rndis_cmd *, int);
-void hvn_rndis_filter(struct hvn_softc *sc, uint64_t, void *);
-void hvn_rndis_input(struct hvn_softc *, caddr_t, uint32_t,
- struct mbuf_list *);
+void hvn_rndis_input(struct hvn_softc *, uint64_t, void *);
+void hvn_rxeof(struct hvn_softc *, caddr_t, uint32_t, struct mbuf_list *);
void hvn_rndis_complete(struct hvn_softc *, caddr_t, uint32_t);
int hvn_rndis_output(struct hvn_softc *, struct hvn_tx_desc *);
void hvn_rndis_status(struct hvn_softc *, caddr_t, uint32_t);
@@ -474,7 +477,6 @@ int
hvn_encap(struct hvn_softc *sc, struct mbuf *m, struct hvn_tx_desc **txd0)
{
struct hvn_tx_desc *txd;
- struct rndis_pkt *pkt;
bus_dma_segment_t *seg;
size_t rlen;
int i;
@@ -487,14 +489,12 @@ hvn_encap(struct hvn_softc *sc, struct mbuf *m, struct hvn_tx_desc **txd0)
txd = &sc->sc_tx_desc[sc->sc_tx_next];
}
- memset(txd->txd_req, 0, HVN_RNDIS_MSG_LEN);
- txd->txd_req->msg_type = RNDIS_PACKET_MSG;
-
- pkt = (struct rndis_pkt *)&txd->txd_req->msg;
- pkt->data_offset = sizeof(struct rndis_pkt);
- pkt->data_length = m->m_pkthdr.len;
- pkt->pkt_info_offset = sizeof(struct rndis_pkt);
- rlen = RNDIS_MESSAGE_SIZE(*pkt);
+ memset(txd->txd_req, 0, sizeof(*txd->txd_req));
+ txd->txd_req->rm_type = REMOTE_NDIS_PACKET_MSG;
+ txd->txd_req->rm_dataoffset = RNDIS_DATA_OFFSET;
+ txd->txd_req->rm_datalen = m->m_pkthdr.len;
+ txd->txd_req->rm_pktinfooffset = RNDIS_DATA_OFFSET;
+ rlen = sizeof(struct rndis_packet_msg);
if (bus_dmamap_load_mbuf(sc->sc_dmat, txd->txd_dmap, m, BUS_DMA_READ |
BUS_DMA_NOWAIT)) {
@@ -506,7 +506,7 @@ hvn_encap(struct hvn_softc *sc, struct mbuf *m, struct hvn_tx_desc **txd0)
/* Per-packet info adjusts rlen */
/* Final length value for the RNDIS header and data */
- txd->txd_req->msg_len = pkt->data_length + rlen;
+ txd->txd_req->rm_len = txd->txd_req->rm_datalen + rlen;
/* Attach an RNDIS message into the first slot */
txd->txd_sgl[0].gpa_page = txd->txd_gpa.gpa_page;
@@ -707,7 +707,7 @@ hvn_tx_ring_create(struct hvn_softc *sc)
txd->txd_gpa.gpa_page = atop(pa);
txd->txd_gpa.gpa_ofs = pa & PAGE_MASK;
txd->txd_gpa.gpa_len = msgsize;
- txd->txd_req = (struct rndis *)((caddr_t)sc->sc_tx_msgs +
+ txd->txd_req = (void *)((caddr_t)sc->sc_tx_msgs +
(msgsize * i));
txd->txd_id = i;
txd->txd_ready = 1;
@@ -765,7 +765,7 @@ hvn_get_lladdr(struct hvn_softc *sc)
size_t addrlen = ETHER_ADDR_LEN;
int rv;
- rv = hvn_rndis_query(sc, RNDIS_OID_802_3_PERMANENT_ADDRESS,
+ rv = hvn_rndis_query(sc, OID_802_3_PERMANENT_ADDRESS,
enaddr, &addrlen);
if (rv == 0 && addrlen == ETHER_ADDR_LEN)
memcpy(sc->sc_ac.ac_enaddr, enaddr, ETHER_ADDR_LEN);
@@ -775,7 +775,7 @@ hvn_get_lladdr(struct hvn_softc *sc)
int
hvn_set_lladdr(struct hvn_softc *sc)
{
- return (hvn_rndis_set(sc, RNDIS_OID_802_3_CURRENT_ADDRESS,
+ return (hvn_rndis_set(sc, OID_802_3_CURRENT_ADDRESS,
sc->sc_ac.ac_enaddr, ETHER_ADDR_LEN));
}
@@ -785,7 +785,7 @@ hvn_get_link_status(struct hvn_softc *sc)
uint32_t state;
size_t len = sizeof(state);
- if (hvn_rndis_query(sc, RNDIS_OID_GEN_MEDIA_CONNECT_STATUS,
+ if (hvn_rndis_query(sc, OID_GEN_MEDIA_CONNECT_STATUS,
&state, &len) == 0)
sc->sc_link_state = (state == 0) ? LINK_STATE_UP :
LINK_STATE_DOWN;
@@ -904,7 +904,7 @@ hvn_nvs_intr(void *arg)
} else if (cph->cph_type == VMBUS_CHANPKT_TYPE_RXBUF) {
switch (nvs->nvs_type) {
case HVN_NVS_TYPE_RNDIS:
- hvn_rndis_filter(sc, cph->cph_tid, cph);
+ hvn_rndis_input(sc, cph->cph_tid, cph);
break;
default:
printf("%s: unhandled NVSP packet type %d "
@@ -1055,7 +1055,7 @@ hvn_rollback_cmd(struct hvn_softc *sc, struct rndis_cmd *rc)
static inline void
hvn_free_cmd(struct hvn_softc *sc, struct rndis_cmd *rc)
{
- memset(rc->rc_req, 0, sizeof(*rc->rc_req));
+ memset(rc->rc_req, 0, sizeof(struct rndis_packet_msg));
memset(&rc->rc_cmp, 0, sizeof(rc->rc_cmp));
memset(&rc->rc_msg, 0, sizeof(rc->rc_msg));
mtx_enter(&sc->sc_cntl_fqlck);
@@ -1088,11 +1088,20 @@ hvn_rndis_attach(struct hvn_softc *sc)
sc->sc_dev.dv_xname);
goto errout;
}
- rc->rc_req = km_alloc(PAGE_SIZE, &kv_any, &kp_zero,
- &kd_waitok);
- if (rc->rc_req == NULL) {
+ if (bus_dmamem_alloc(sc->sc_dmat, PAGE_SIZE, PAGE_SIZE,
+ 0, &rc->rc_segs, 1, &rc->rc_nsegs, BUS_DMA_NOWAIT |
+ BUS_DMA_ZERO)) {
+ DPRINTF("%s: failed to allocate RNDIS command\n",
+ sc->sc_dev.dv_xname);
+ bus_dmamap_destroy(sc->sc_dmat, rc->rc_dmap);
+ goto errout;
+ }
+ if (bus_dmamem_map(sc->sc_dmat, &rc->rc_segs, rc->rc_nsegs,
+ PAGE_SIZE, (caddr_t *)&rc->rc_req, BUS_DMA_NOWAIT)) {
DPRINTF("%s: failed to allocate RNDIS command\n",
sc->sc_dev.dv_xname);
+ bus_dmamem_free(sc->sc_dmat, &rc->rc_segs,
+ rc->rc_nsegs);
bus_dmamap_destroy(sc->sc_dmat, rc->rc_dmap);
goto errout;
}
@@ -1100,7 +1109,8 @@ hvn_rndis_attach(struct hvn_softc *sc)
PAGE_SIZE, NULL, BUS_DMA_WAITOK)) {
DPRINTF("%s: failed to load RNDIS command map\n",
sc->sc_dev.dv_xname);
- km_free(rc->rc_req, PAGE_SIZE, &kv_any, &kp_zero);
+ bus_dmamem_free(sc->sc_dmat, &rc->rc_segs,
+ rc->rc_nsegs);
bus_dmamap_destroy(sc->sc_dmat, rc->rc_dmap);
goto errout;
}
@@ -1114,15 +1124,17 @@ hvn_rndis_attach(struct hvn_softc *sc)
bus_dmamap_sync(sc->sc_dmat, rc->rc_dmap, 0, PAGE_SIZE,
BUS_DMASYNC_PREREAD);
- rc->rc_req->msg_type = RNDIS_INITIALIZE_MSG;
- rc->rc_req->msg_len = RNDIS_MESSAGE_SIZE(*req);
- rc->rc_cmplen = RNDIS_MESSAGE_SIZE(*cmp);
rc->rc_id = atomic_inc_int_nv(&sc->sc_rndisrid);
- req = (struct rndis_init_req *)&rc->rc_req->msg;
- req->request_id = rc->rc_id;
- req->major_version = RNDIS_MAJOR_VERSION;
- req->minor_version = RNDIS_MINOR_VERSION;
- req->max_xfer_size = 2048; /* XXX */
+
+ req = rc->rc_req;
+ req->rm_type = REMOTE_NDIS_INITIALIZE_MSG;
+ req->rm_len = sizeof(*req);
+ req->rm_rid = rc->rc_id;
+ req->rm_ver_major = RNDIS_VERSION_MAJOR;
+ req->rm_ver_minor = RNDIS_VERSION_MINOR;
+ req->rm_max_xfersz = 2048; /* XXX */
+
+ rc->rc_cmplen = sizeof(*cmp);
bus_dmamap_sync(sc->sc_dmat, rc->rc_dmap, 0, PAGE_SIZE,
BUS_DMASYNC_PREWRITE);
@@ -1133,10 +1145,10 @@ hvn_rndis_attach(struct hvn_softc *sc)
hvn_free_cmd(sc, rc);
goto errout;
}
- cmp = (struct rndis_init_comp *)&rc->rc_cmp.msg;
- if (cmp->status != RNDIS_STATUS_SUCCESS) {
+ cmp = (struct rndis_init_comp *)&rc->rc_cmp;
+ if (cmp->rm_status != RNDIS_STATUS_SUCCESS) {
DPRINTF("%s: failed to init RNDIS, error %#x\n",
- sc->sc_dev.dv_xname, cmp->status);
+ sc->sc_dev.dv_xname, cmp->rm_status);
hvn_free_cmd(sc, rc);
goto errout;
}
@@ -1151,7 +1163,7 @@ errout:
if (rc->rc_req == NULL)
continue;
TAILQ_REMOVE(&sc->sc_cntl_fq, rc, rc_entry);
- km_free(rc->rc_req, PAGE_SIZE, &kv_any, &kp_zero);
+ bus_dmamem_free(sc->sc_dmat, &rc->rc_segs, rc->rc_nsegs);
rc->rc_req = NULL;
bus_dmamap_destroy(sc->sc_dmat, rc->rc_dmap);
}
@@ -1162,6 +1174,7 @@ int
hvn_rndis_cmd(struct hvn_softc *sc, struct rndis_cmd *rc, int timo)
{
struct hvn_nvs_rndis *msg = &rc->rc_msg;
+ struct rndis_msghdr *hdr = rc->rc_req;
struct vmbus_gpa sgl[1];
int tries = 10;
int rv;
@@ -1173,7 +1186,7 @@ hvn_rndis_cmd(struct hvn_softc *sc, struct rndis_cmd *rc, int timo)
msg->nvs_chim_idx = HVN_NVS_CHIM_IDX_INVALID;
sgl[0].gpa_page = rc->rc_gpa;
- sgl[0].gpa_len = rc->rc_req->msg_len;
+ sgl[0].gpa_len = hdr->rm_len;
sgl[0].gpa_ofs = 0;
hvn_submit_cmd(sc, rc);
@@ -1185,7 +1198,7 @@ hvn_rndis_cmd(struct hvn_softc *sc, struct rndis_cmd *rc, int timo)
tsleep(rc, PRIBIO, "hvnsendbuf", timo / 10);
else if (rv) {
DPRINTF("%s: RNDIS operation %d send error %d\n",
- sc->sc_dev.dv_xname, rc->rc_req->msg_type, rv);
+ sc->sc_dev.dv_xname, hdr->rm_type, rv);
return (rv);
}
} while (rv != 0 && --tries > 0);
@@ -1213,14 +1226,14 @@ hvn_rndis_cmd(struct hvn_softc *sc, struct rndis_cmd *rc, int timo)
break;
}
printf("%s: RNDIS opertaion %d timed out\n", sc->sc_dev.dv_xname,
- rc->rc_req->msg_type);
+ hdr->rm_type);
}
#endif
return (rv);
}
void
-hvn_rndis_filter(struct hvn_softc *sc, uint64_t tid, void *arg)
+hvn_rndis_input(struct hvn_softc *sc, uint64_t tid, void *arg)
{
struct ifnet *ifp = &sc->sc_ac.ac_if;
struct mbuf_list ml = MBUF_LIST_INITIALIZER();
@@ -1237,26 +1250,26 @@ hvn_rndis_filter(struct hvn_softc *sc, uint64_t tid, void *arg)
len = cp->cp_range[i].gpa_len;
KASSERT(off + len <= sc->sc_rx_size);
- KASSERT(len >= RNDIS_HEADER_SIZE + 4);
+ KASSERT(len >= RNDIS_HEADER_OFFSET + 4);
memcpy(&type, (caddr_t)sc->sc_rx_ring + off, sizeof(type));
switch (type) {
/* data message */
- case RNDIS_PACKET_MSG:
- hvn_rndis_input(sc, (caddr_t)sc->sc_rx_ring +
+ case REMOTE_NDIS_PACKET_MSG:
+ hvn_rxeof(sc, (caddr_t)sc->sc_rx_ring +
off, len, &ml);
break;
/* completion messages */
- case RNDIS_INITIALIZE_CMPLT:
- case RNDIS_QUERY_CMPLT:
- case RNDIS_SET_CMPLT:
- case RNDIS_RESET_CMPLT:
- case RNDIS_KEEPALIVE_CMPLT:
+ case REMOTE_NDIS_INITIALIZE_CMPLT:
+ case REMOTE_NDIS_QUERY_CMPLT:
+ case REMOTE_NDIS_SET_CMPLT:
+ case REMOTE_NDIS_RESET_CMPLT:
+ case REMOTE_NDIS_KEEPALIVE_CMPLT:
hvn_rndis_complete(sc, (caddr_t)sc->sc_rx_ring +
off, len);
break;
/* notification message */
- case RNDIS_INDICATE_STATUS_MSG:
+ case REMOTE_NDIS_INDICATE_STATUS_MSG:
hvn_rndis_status(sc, (caddr_t)sc->sc_rx_ring +
off, len);
break;
@@ -1294,12 +1307,12 @@ hvn_devget(struct hvn_softc *sc, caddr_t buf, uint32_t len)
}
void
-hvn_rndis_input(struct hvn_softc *sc, caddr_t buf, uint32_t len,
+hvn_rxeof(struct hvn_softc *sc, caddr_t buf, uint32_t len,
struct mbuf_list *ml)
{
struct ifnet *ifp = &sc->sc_ac.ac_if;
- struct rndis_pkt *pkt;
- struct rndis_pkt_info *ppi;
+ struct rndis_packet_msg *pkt;
+ struct rndis_pktinfo *pi;
struct rndis_tcp_ip_csum_info *csum;
struct ndis_8021q_info *vlan;
struct mbuf *m;
@@ -1307,45 +1320,45 @@ hvn_rndis_input(struct hvn_softc *sc, caddr_t buf, uint32_t len,
if (!(ifp->if_flags & IFF_RUNNING))
return;
- if (len < RNDIS_HEADER_SIZE + sizeof(*pkt)) {
+ if (len < RNDIS_HEADER_OFFSET + sizeof(*pkt)) {
printf("%s: data packet too short: %u\n",
sc->sc_dev.dv_xname, len);
return;
}
- pkt = (struct rndis_pkt *)(buf + RNDIS_HEADER_SIZE);
+ pkt = (struct rndis_packet_msg *)buf;
- if (pkt->data_offset + pkt->data_length > len) {
+ if (pkt->rm_dataoffset + pkt->rm_datalen > len) {
printf("%s: data packet out of bounds: %u@%u\n",
- sc->sc_dev.dv_xname, pkt->data_offset, pkt->data_length);
+ sc->sc_dev.dv_xname, pkt->rm_dataoffset, pkt->rm_datalen);
return;
}
- if ((m = hvn_devget(sc, buf + RNDIS_HEADER_SIZE + pkt->data_offset,
- pkt->data_length)) == NULL) {
+ if ((m = hvn_devget(sc, buf + RNDIS_HEADER_OFFSET + pkt->rm_dataoffset,
+ pkt->rm_datalen)) == NULL) {
ifp->if_ierrors++;
return;
}
- while (pkt->pkt_info_length > 0) {
- if (pkt->pkt_info_offset + pkt->pkt_info_length > len) {
- printf("%s: PPI out of bounds: %u@%u\n",
- sc->sc_dev.dv_xname, pkt->pkt_info_length,
- pkt->pkt_info_offset);
+ pi = (struct rndis_pktinfo *)((caddr_t)pkt + RNDIS_HEADER_OFFSET +
+ pkt->rm_pktinfooffset);
+ while (pkt->rm_pktinfolen > 0) {
+ if (pkt->rm_pktinfooffset + pkt->rm_pktinfolen > len) {
+ printf("%s: PI out of bounds: %u@%u\n",
+ sc->sc_dev.dv_xname, pkt->rm_pktinfolen,
+ pkt->rm_pktinfooffset);
break;
}
- ppi = (struct rndis_pkt_info *)((caddr_t)pkt +
- pkt->pkt_info_offset);
- if (ppi->size > pkt->pkt_info_length) {
- printf("%s: invalid PPI size: %u/%u\n",
- sc->sc_dev.dv_xname, ppi->size,
- pkt->pkt_info_length);
+ if (pi->rm_size > pkt->rm_pktinfolen) {
+ printf("%s: invalid PI size: %u/%u\n",
+ sc->sc_dev.dv_xname, pi->rm_size,
+ pkt->rm_pktinfolen);
break;
}
- switch (ppi->type) {
- case tcpip_chksum_info:
+ switch (pi->rm_type) {
+ case NDIS_PKTINFO_TYPE_CSUM:
csum = (struct rndis_tcp_ip_csum_info *)
- ((caddr_t)ppi + ppi->size);
+ ((caddr_t)pi + pi->rm_size);
if (csum->recv.ip_csum_succeeded)
m->m_pkthdr.csum_flags |= M_IPV4_CSUM_IN_OK;
if (csum->recv.tcp_csum_succeeded)
@@ -1353,19 +1366,20 @@ hvn_rndis_input(struct hvn_softc *sc, caddr_t buf, uint32_t len,
if (csum->recv.udp_csum_succeeded)
m->m_pkthdr.csum_flags |= M_UDP_CSUM_IN_OK;
break;
- case ieee_8021q_info:
+ case NDIS_PKTINFO_TYPE_VLAN:
vlan = (struct ndis_8021q_info *)
- ((caddr_t)ppi + ppi->size);
+ ((caddr_t)pi + pi->rm_size);
#if NVLAN > 0
m->m_pkthdr.ether_vtag = vlan->vlan_id;
m->m_flags |= M_VLANTAG;
#endif
break;
default:
- DPRINTF("%s: unhandled PPI %u\n", sc->sc_dev.dv_xname,
- ppi->type);
+ DPRINTF("%s: unhandled PI %u\n", sc->sc_dev.dv_xname,
+ pi->rm_type);
}
- pkt->pkt_info_length -= ppi->size;
+ pkt->rm_pktinfolen -= pi->rm_size;
+ pi = (struct rndis_pktinfo *)((caddr_t)pi + pi->rm_size);
}
ml_enqueue(ml, m);
@@ -1377,7 +1391,7 @@ hvn_rndis_complete(struct hvn_softc *sc, caddr_t buf, uint32_t len)
struct rndis_cmd *rc;
uint32_t id;
- memcpy(&id, buf + RNDIS_HEADER_SIZE, sizeof(id));
+ memcpy(&id, buf + RNDIS_HEADER_OFFSET, sizeof(id));
if ((rc = hvn_complete_cmd(sc, id)) != NULL) {
if (len < rc->rc_cmplen)
printf("%s: RNDIS response %u too short: %u\n",
@@ -1423,7 +1437,7 @@ hvn_rndis_status(struct hvn_softc *sc, caddr_t buf, uint32_t len)
{
uint32_t sta;
- memcpy(&sta, buf + RNDIS_HEADER_SIZE, sizeof(sta));
+ memcpy(&sta, buf + RNDIS_HEADER_OFFSET, sizeof(sta));
switch (sta) {
case RNDIS_STATUS_MEDIA_CONNECT:
sc->sc_link_state = LINK_STATE_UP;
@@ -1457,14 +1471,16 @@ hvn_rndis_query(struct hvn_softc *sc, uint32_t oid, void *res, size_t *length)
bus_dmamap_sync(sc->sc_dmat, rc->rc_dmap, 0, PAGE_SIZE,
BUS_DMASYNC_PREREAD);
- rc->rc_req->msg_type = RNDIS_QUERY_MSG;
- rc->rc_req->msg_len = RNDIS_MESSAGE_SIZE(*req);
- rc->rc_cmplen = RNDIS_MESSAGE_SIZE(*cmp);
rc->rc_id = atomic_inc_int_nv(&sc->sc_rndisrid);
- req = (struct rndis_query_req *)&rc->rc_req->msg;
- req->request_id = rc->rc_id;
- req->oid = oid;
- req->info_buffer_offset = sizeof(*req);
+
+ req = rc->rc_req;
+ req->rm_type = REMOTE_NDIS_QUERY_MSG;
+ req->rm_len = sizeof(*req);
+ req->rm_rid = rc->rc_id;
+ req->rm_oid = oid;
+ req->rm_infobufoffset = sizeof(*req) - RNDIS_HEADER_OFFSET;
+
+ rc->rc_cmplen = sizeof(*cmp);
bus_dmamap_sync(sc->sc_dmat, rc->rc_dmap, 0, PAGE_SIZE,
BUS_DMASYNC_PREWRITE);
@@ -1476,15 +1492,15 @@ hvn_rndis_query(struct hvn_softc *sc, uint32_t oid, void *res, size_t *length)
return (rv);
}
- cmp = (struct rndis_query_comp *)&rc->rc_cmp.msg;
- switch (cmp->status) {
+ cmp = (struct rndis_query_comp *)&rc->rc_cmp;
+ switch (cmp->rm_status) {
case RNDIS_STATUS_SUCCESS:
- if (cmp->info_buffer_length > olength) {
+ if (cmp->rm_infobuflen > olength) {
rv = EINVAL;
break;
}
- memcpy(res, rc->rc_cmpbuf, cmp->info_buffer_length);
- *length = cmp->info_buffer_length;
+ memcpy(res, rc->rc_cmpbuf, cmp->rm_infobuflen);
+ *length = cmp->rm_infobuflen;
break;
default:
*length = 0;
@@ -1509,19 +1525,20 @@ hvn_rndis_set(struct hvn_softc *sc, uint32_t oid, void *data, size_t length)
bus_dmamap_sync(sc->sc_dmat, rc->rc_dmap, 0, PAGE_SIZE,
BUS_DMASYNC_PREREAD);
- rc->rc_req->msg_type = RNDIS_SET_MSG;
- rc->rc_req->msg_len = RNDIS_MESSAGE_SIZE(*req) + length;
- rc->rc_cmplen = RNDIS_MESSAGE_SIZE(*cmp);
rc->rc_id = atomic_inc_int_nv(&sc->sc_rndisrid);
- req = (struct rndis_set_req *)&rc->rc_req->msg;
- memset(req, 0, sizeof(*req));
- req->request_id = rc->rc_id;
- req->oid = oid;
- req->info_buffer_offset = sizeof(*req);
+
+ req = rc->rc_req;
+ req->rm_type = REMOTE_NDIS_SET_MSG;
+ req->rm_len = sizeof(*req) + length;
+ req->rm_rid = rc->rc_id;
+ req->rm_oid = oid;
+ req->rm_infobufoffset = sizeof(*req) - RNDIS_HEADER_OFFSET;
+
+ rc->rc_cmplen = sizeof(*cmp);
if (length > 0) {
- KASSERT(sizeof(*req) + length < sizeof(struct rndis));
- req->info_buffer_length = length;
+ KASSERT(sizeof(*req) + length < PAGE_SIZE);
+ req->rm_infobuflen = length;
memcpy((caddr_t)(req + 1), data, length);
}
@@ -1535,8 +1552,8 @@ hvn_rndis_set(struct hvn_softc *sc, uint32_t oid, void *data, size_t length)
return (rv);
}
- cmp = (struct rndis_set_comp *)&rc->rc_cmp.msg;
- if (cmp->status != RNDIS_STATUS_SUCCESS)
+ cmp = (struct rndis_set_comp *)&rc->rc_cmp;
+ if (cmp->rm_status != RNDIS_STATUS_SUCCESS)
rv = EIO;
hvn_free_cmd(sc, rc);
@@ -1557,7 +1574,7 @@ hvn_rndis_open(struct hvn_softc *sc)
NDIS_PACKET_TYPE_ALL_MULTICAST |
NDIS_PACKET_TYPE_DIRECTED;
- rv = hvn_rndis_set(sc, RNDIS_OID_GEN_CURRENT_PACKET_FILTER,
+ rv = hvn_rndis_set(sc, OID_GEN_CURRENT_PACKET_FILTER,
&filter, sizeof(filter));
if (rv)
DPRINTF("%s: failed to set RNDIS filter to %#x\n",
@@ -1571,7 +1588,7 @@ hvn_rndis_close(struct hvn_softc *sc)
uint32_t filter = 0;
int rv;
- rv = hvn_rndis_set(sc, RNDIS_OID_GEN_CURRENT_PACKET_FILTER,
+ rv = hvn_rndis_set(sc, OID_GEN_CURRENT_PACKET_FILTER,
&filter, sizeof(filter));
if (rv)
DPRINTF("%s: failed to clear RNDIS filter\n",
@@ -1591,11 +1608,12 @@ hvn_rndis_detach(struct hvn_softc *sc)
bus_dmamap_sync(sc->sc_dmat, rc->rc_dmap, 0, PAGE_SIZE,
BUS_DMASYNC_PREREAD);
- rc->rc_req->msg_type = RNDIS_HALT_MSG;
- rc->rc_req->msg_len = RNDIS_MESSAGE_SIZE(*req);
rc->rc_id = atomic_inc_int_nv(&sc->sc_rndisrid);
- req = (struct rndis_halt_req *)&rc->rc_req->msg;
- req->request_id = rc->rc_id;
+
+ req = rc->rc_req;
+ req->rm_type = REMOTE_NDIS_HALT_MSG;
+ req->rm_len = sizeof(*req);
+ req->rm_rid = rc->rc_id;
bus_dmamap_sync(sc->sc_dmat, rc->rc_dmap, 0, PAGE_SIZE,
BUS_DMASYNC_PREWRITE);
diff --git a/sys/dev/pv/rndisreg.h b/sys/dev/pv/rndisreg.h
index da504d78c46..58e3de8c3b7 100644
--- a/sys/dev/pv/rndisreg.h
+++ b/sys/dev/pv/rndisreg.h
@@ -38,571 +38,8 @@
#define NDIS_VERSION_6_1 0x00060001
#define NDIS_VERSION_6_30 0x0006001e
-/*
- * Status codes
- */
-
-#define STATUS_SUCCESS 0x00000000
-#define STATUS_UNSUCCESSFUL 0xC0000001
-#define STATUS_PENDING 0x00000103
-#define STATUS_INSUFFICIENT_RESOURCES 0xC000009A
-#define STATUS_BUFFER_OVERFLOW 0x80000005
-#define STATUS_NOT_SUPPORTED 0xC00000BB
-
-#define RNDIS_STATUS_SUCCESS 0x00000000
-#define RNDIS_STATUS_PENDING 0x00000103
-#define RNDIS_STATUS_NOT_RECOGNIZED 0x00010001
-#define RNDIS_STATUS_NOT_COPIED 0x00010002
-#define RNDIS_STATUS_NOT_ACCEPTED 0x00010003
-#define RNDIS_STATUS_CALL_ACTIVE 0x00010007
-
-#define RNDIS_STATUS_ONLINE 0x40010003
-#define RNDIS_STATUS_RESET_START 0x40010004
-#define RNDIS_STATUS_RESET_END 0x40010005
-#define RNDIS_STATUS_RING_STATUS 0x40010006
-#define RNDIS_STATUS_CLOSED 0x40010007
-#define RNDIS_STATUS_WAN_LINE_UP 0x40010008
-#define RNDIS_STATUS_WAN_LINE_DOWN 0x40010009
-#define RNDIS_STATUS_WAN_FRAGMENT 0x4001000A
-#define RNDIS_STATUS_MEDIA_CONNECT 0x4001000B
-#define RNDIS_STATUS_MEDIA_DISCONNECT 0x4001000C
-#define RNDIS_STATUS_HARDWARE_LINE_UP 0x4001000D
-#define RNDIS_STATUS_HARDWARE_LINE_DOWN 0x4001000E
-#define RNDIS_STATUS_INTERFACE_UP 0x4001000F
-#define RNDIS_STATUS_INTERFACE_DOWN 0x40010010
-#define RNDIS_STATUS_MEDIA_BUSY 0x40010011
-#define RNDIS_STATUS_MEDIA_SPECIFIC_INDICATION 0x40010012
-#define RNDIS_STATUS_WW_INDICATION 0x40010012
-#define RNDIS_STATUS_LINK_SPEED_CHANGE 0x40010013
-
#define RNDIS_STATUS_OFFLOAD_CURRENT_CONFIG 0x40020006
-#define RNDIS_STATUS_NOT_RESETTABLE 0x80010001
-#define RNDIS_STATUS_SOFT_ERRORS 0x80010003
-#define RNDIS_STATUS_HARD_ERRORS 0x80010004
-#define RNDIS_STATUS_BUFFER_OVERFLOW 0x80000005
-
-#define RNDIS_STATUS_FAILURE 0xC0000001
-#define RNDIS_STATUS_RESOURCES 0xC000009A
-#define RNDIS_STATUS_CLOSING 0xC0010002
-#define RNDIS_STATUS_BAD_VERSION 0xC0010004
-#define RNDIS_STATUS_BAD_CHARACTERISTICS 0xC0010005
-#define RNDIS_STATUS_ADAPTER_NOT_FOUND 0xC0010006
-#define RNDIS_STATUS_OPEN_FAILED 0xC0010007
-#define RNDIS_STATUS_DEVICE_FAILED 0xC0010008
-#define RNDIS_STATUS_MULTICAST_FULL 0xC0010009
-#define RNDIS_STATUS_MULTICAST_EXISTS 0xC001000A
-#define RNDIS_STATUS_MULTICAST_NOT_FOUND 0xC001000B
-#define RNDIS_STATUS_REQUEST_ABORTED 0xC001000C
-#define RNDIS_STATUS_RESET_IN_PROGRESS 0xC001000D
-#define RNDIS_STATUS_CLOSING_INDICATING 0xC001000E
-#define RNDIS_STATUS_NOT_SUPPORTED 0xC00000BB
-#define RNDIS_STATUS_INVALID_PACKET 0xC001000F
-#define RNDIS_STATUS_OPEN_LIST_FULL 0xC0010010
-#define RNDIS_STATUS_ADAPTER_NOT_READY 0xC0010011
-#define RNDIS_STATUS_ADAPTER_NOT_OPEN 0xC0010012
-#define RNDIS_STATUS_NOT_INDICATING 0xC0010013
-#define RNDIS_STATUS_INVALID_LENGTH 0xC0010014
-#define RNDIS_STATUS_INVALID_DATA 0xC0010015
-#define RNDIS_STATUS_BUFFER_TOO_SHORT 0xC0010016
-#define RNDIS_STATUS_INVALID_OID 0xC0010017
-#define RNDIS_STATUS_ADAPTER_REMOVED 0xC0010018
-#define RNDIS_STATUS_UNSUPPORTED_MEDIA 0xC0010019
-#define RNDIS_STATUS_GROUP_ADDRESS_IN_USE 0xC001001A
-#define RNDIS_STATUS_FILE_NOT_FOUND 0xC001001B
-#define RNDIS_STATUS_ERROR_READING_FILE 0xC001001C
-#define RNDIS_STATUS_ALREADY_MAPPED 0xC001001D
-#define RNDIS_STATUS_RESOURCE_CONFLICT 0xC001001E
-#define RNDIS_STATUS_NO_CABLE 0xC001001F
-
-#define RNDIS_STATUS_INVALID_SAP 0xC0010020
-#define RNDIS_STATUS_SAP_IN_USE 0xC0010021
-#define RNDIS_STATUS_INVALID_ADDRESS 0xC0010022
-#define RNDIS_STATUS_VC_NOT_ACTIVATED 0xC0010023
-#define RNDIS_STATUS_DEST_OUT_OF_ORDER 0xC0010024
-#define RNDIS_STATUS_VC_NOT_AVAILABLE 0xC0010025
-#define RNDIS_STATUS_CELLRATE_NOT_AVAILABLE 0xC0010026
-#define RNDIS_STATUS_INCOMPATABLE_QOS 0xC0010027
-#define RNDIS_STATUS_AAL_PARAMS_UNSUPPORTED 0xC0010028
-#define RNDIS_STATUS_NO_ROUTE_TO_DESTINATION 0xC0010029
-
-#define RNDIS_STATUS_TOKEN_RING_OPEN_ERROR 0xC0011000
-
-
-/*
- * Object Identifiers used by NdisRequest Query/Set Information
- */
-
-/*
- * General Objects
- */
-
-#define RNDIS_OID_GEN_SUPPORTED_LIST 0x00010101
-#define RNDIS_OID_GEN_HARDWARE_STATUS 0x00010102
-#define RNDIS_OID_GEN_MEDIA_SUPPORTED 0x00010103
-#define RNDIS_OID_GEN_MEDIA_IN_USE 0x00010104
-#define RNDIS_OID_GEN_MAXIMUM_LOOKAHEAD 0x00010105
-#define RNDIS_OID_GEN_MAXIMUM_FRAME_SIZE 0x00010106
-#define RNDIS_OID_GEN_LINK_SPEED 0x00010107
-#define RNDIS_OID_GEN_TRANSMIT_BUFFER_SPACE 0x00010108
-#define RNDIS_OID_GEN_RECEIVE_BUFFER_SPACE 0x00010109
-#define RNDIS_OID_GEN_TRANSMIT_BLOCK_SIZE 0x0001010A
-#define RNDIS_OID_GEN_RECEIVE_BLOCK_SIZE 0x0001010B
-#define RNDIS_OID_GEN_VENDOR_ID 0x0001010C
-#define RNDIS_OID_GEN_VENDOR_DESCRIPTION 0x0001010D
-#define RNDIS_OID_GEN_CURRENT_PACKET_FILTER 0x0001010E
-#define RNDIS_OID_GEN_CURRENT_LOOKAHEAD 0x0001010F
-#define RNDIS_OID_GEN_DRIVER_VERSION 0x00010110
-#define RNDIS_OID_GEN_MAXIMUM_TOTAL_SIZE 0x00010111
-#define RNDIS_OID_GEN_PROTOCOL_OPTIONS 0x00010112
-#define RNDIS_OID_GEN_MAC_OPTIONS 0x00010113
-#define RNDIS_OID_GEN_MEDIA_CONNECT_STATUS 0x00010114
-#define RNDIS_OID_GEN_MAXIMUM_SEND_PACKETS 0x00010115
-#define RNDIS_OID_GEN_VENDOR_DRIVER_VERSION 0x00010116
-#define RNDIS_OID_GEN_NETWORK_LAYER_ADDRESSES 0x00010118
-#define RNDIS_OID_GEN_TRANSPORT_HEADER_OFFSET 0x00010119
-#define RNDIS_OID_GEN_MACHINE_NAME 0x0001021A
-#define RNDIS_OID_GEN_RNDIS_CONFIG_PARAMETER 0x0001021B
-
-#define RNDIS_OID_GEN_XMIT_OK 0x00020101
-#define RNDIS_OID_GEN_RCV_OK 0x00020102
-#define RNDIS_OID_GEN_XMIT_ERROR 0x00020103
-#define RNDIS_OID_GEN_RCV_ERROR 0x00020104
-#define RNDIS_OID_GEN_RCV_NO_BUFFER 0x00020105
-
-#define RNDIS_OID_GEN_DIRECTED_BYTES_XMIT 0x00020201
-#define RNDIS_OID_GEN_DIRECTED_FRAMES_XMIT 0x00020202
-#define RNDIS_OID_GEN_MULTICAST_BYTES_XMIT 0x00020203
-#define RNDIS_OID_GEN_MULTICAST_FRAMES_XMIT 0x00020204
-#define RNDIS_OID_GEN_BROADCAST_BYTES_XMIT 0x00020205
-#define RNDIS_OID_GEN_BROADCAST_FRAMES_XMIT 0x00020206
-#define RNDIS_OID_GEN_DIRECTED_BYTES_RCV 0x00020207
-#define RNDIS_OID_GEN_DIRECTED_FRAMES_RCV 0x00020208
-#define RNDIS_OID_GEN_MULTICAST_BYTES_RCV 0x00020209
-#define RNDIS_OID_GEN_MULTICAST_FRAMES_RCV 0x0002020A
-#define RNDIS_OID_GEN_BROADCAST_BYTES_RCV 0x0002020B
-#define RNDIS_OID_GEN_BROADCAST_FRAMES_RCV 0x0002020C
-
-#define RNDIS_OID_GEN_RCV_CRC_ERROR 0x0002020D
-#define RNDIS_OID_GEN_TRANSMIT_QUEUE_LENGTH 0x0002020E
-
-#define RNDIS_OID_GEN_GET_TIME_CAPS 0x0002020F
-#define RNDIS_OID_GEN_GET_NETCARD_TIME 0x00020210
-
-/*
- * These are connection-oriented general OIDs.
- * These replace the above OIDs for connection-oriented media.
- */
-#define RNDIS_OID_GEN_CO_SUPPORTED_LIST 0x00010101
-#define RNDIS_OID_GEN_CO_HARDWARE_STATUS 0x00010102
-#define RNDIS_OID_GEN_CO_MEDIA_SUPPORTED 0x00010103
-#define RNDIS_OID_GEN_CO_MEDIA_IN_USE 0x00010104
-#define RNDIS_OID_GEN_CO_LINK_SPEED 0x00010105
-#define RNDIS_OID_GEN_CO_VENDOR_ID 0x00010106
-#define RNDIS_OID_GEN_CO_VENDOR_DESCRIPTION 0x00010107
-#define RNDIS_OID_GEN_CO_DRIVER_VERSION 0x00010108
-#define RNDIS_OID_GEN_CO_PROTOCOL_OPTIONS 0x00010109
-#define RNDIS_OID_GEN_CO_MAC_OPTIONS 0x0001010A
-#define RNDIS_OID_GEN_CO_MEDIA_CONNECT_STATUS 0x0001010B
-#define RNDIS_OID_GEN_CO_VENDOR_DRIVER_VERSION 0x0001010C
-#define RNDIS_OID_GEN_CO_MINIMUM_LINK_SPEED 0x0001010D
-
-#define RNDIS_OID_GEN_CO_GET_TIME_CAPS 0x00010201
-#define RNDIS_OID_GEN_CO_GET_NETCARD_TIME 0x00010202
-
-/*
- * These are connection-oriented statistics OIDs.
- */
-#define RNDIS_OID_GEN_CO_XMIT_PDUS_OK 0x00020101
-#define RNDIS_OID_GEN_CO_RCV_PDUS_OK 0x00020102
-#define RNDIS_OID_GEN_CO_XMIT_PDUS_ERROR 0x00020103
-#define RNDIS_OID_GEN_CO_RCV_PDUS_ERROR 0x00020104
-#define RNDIS_OID_GEN_CO_RCV_PDUS_NO_BUFFER 0x00020105
-
-
-#define RNDIS_OID_GEN_CO_RCV_CRC_ERROR 0x00020201
-#define RNDIS_OID_GEN_CO_TRANSMIT_QUEUE_LENGTH 0x00020202
-#define RNDIS_OID_GEN_CO_BYTES_XMIT 0x00020203
-#define RNDIS_OID_GEN_CO_BYTES_RCV 0x00020204
-#define RNDIS_OID_GEN_CO_BYTES_XMIT_OUTSTANDING 0x00020205
-#define RNDIS_OID_GEN_CO_NETCARD_LOAD 0x00020206
-
-/*
- * These are objects for Connection-oriented media call-managers.
- */
-#define RNDIS_OID_CO_ADD_PVC 0xFF000001
-#define RNDIS_OID_CO_DELETE_PVC 0xFF000002
-#define RNDIS_OID_CO_GET_CALL_INFORMATION 0xFF000003
-#define RNDIS_OID_CO_ADD_ADDRESS 0xFF000004
-#define RNDIS_OID_CO_DELETE_ADDRESS 0xFF000005
-#define RNDIS_OID_CO_GET_ADDRESSES 0xFF000006
-#define RNDIS_OID_CO_ADDRESS_CHANGE 0xFF000007
-#define RNDIS_OID_CO_SIGNALING_ENABLED 0xFF000008
-#define RNDIS_OID_CO_SIGNALING_DISABLED 0xFF000009
-
-
-/*
- * 802.3 Objects (Ethernet)
- */
-
-#define RNDIS_OID_802_3_PERMANENT_ADDRESS 0x01010101
-#define RNDIS_OID_802_3_CURRENT_ADDRESS 0x01010102
-#define RNDIS_OID_802_3_MULTICAST_LIST 0x01010103
-#define RNDIS_OID_802_3_MAXIMUM_LIST_SIZE 0x01010104
-#define RNDIS_OID_802_3_MAC_OPTIONS 0x01010105
-
-/*
- *
- */
-#define NDIS_802_3_MAC_OPTION_PRIORITY 0x00000001
-
-#define RNDIS_OID_802_3_RCV_ERROR_ALIGNMENT 0x01020101
-#define RNDIS_OID_802_3_XMIT_ONE_COLLISION 0x01020102
-#define RNDIS_OID_802_3_XMIT_MORE_COLLISIONS 0x01020103
-
-#define RNDIS_OID_802_3_XMIT_DEFERRED 0x01020201
-#define RNDIS_OID_802_3_XMIT_MAX_COLLISIONS 0x01020202
-#define RNDIS_OID_802_3_RCV_OVERRUN 0x01020203
-#define RNDIS_OID_802_3_XMIT_UNDERRUN 0x01020204
-#define RNDIS_OID_802_3_XMIT_HEARTBEAT_FAILURE 0x01020205
-#define RNDIS_OID_802_3_XMIT_TIMES_CRS_LOST 0x01020206
-#define RNDIS_OID_802_3_XMIT_LATE_COLLISIONS 0x01020207
-
-
-/*
- * RNDIS MP custom OID for test
- */
-#define OID_RNDISMP_GET_RECEIVE_BUFFERS 0xFFA0C90D
-
-
-/*
- * Remote NDIS message types
- */
-#define RNDIS_PACKET_MSG 0x00000001
-#define RNDIS_INITIALIZE_MSG 0x00000002
-#define RNDIS_HALT_MSG 0x00000003
-#define RNDIS_QUERY_MSG 0x00000004
-#define RNDIS_SET_MSG 0x00000005
-#define RNDIS_RESET_MSG 0x00000006
-#define RNDIS_INDICATE_STATUS_MSG 0x00000007
-#define RNDIS_KEEPALIVE_MSG 0x00000008
-
-#define RCONDIS_MP_CREATE_VC_MSG 0x00008001
-#define RCONDIS_MP_DELETE_VC_MSG 0x00008002
-#define RCONDIS_MP_ACTIVATE_VC_MSG 0x00008005
-#define RCONDIS_MP_DEACTIVATE_VC_MSG 0x00008006
-#define RCONDIS_INDICATE_STATUS_MSG 0x00008007
-
-/*
- * Remote NDIS message completion types
- */
-#define RNDIS_INITIALIZE_CMPLT 0x80000002
-#define RNDIS_QUERY_CMPLT 0x80000004
-#define RNDIS_SET_CMPLT 0x80000005
-#define RNDIS_RESET_CMPLT 0x80000006
-#define RNDIS_KEEPALIVE_CMPLT 0x80000008
-
-#define RCONDIS_MP_CREATE_VC_CMPLT 0x80008001
-#define RCONDIS_MP_DELETE_VC_CMPLT 0x80008002
-#define RCONDIS_MP_ACTIVATE_VC_CMPLT 0x80008005
-#define RCONDIS_MP_DEACTIVATE_VC_CMPLT 0x80008006
-
-/*
- * Reserved message type for private communication between
- * lower-layer host driver and remote device, if necessary.
- */
-#define RNDIS_BUS_MSG 0xff000001
-
-/*
- * Defines for DeviceFlags in rndis_initialize_comp
- */
-#define RNDIS_DF_CONNECTIONLESS 0x00000001
-#define RNDIS_DF_CONNECTION_ORIENTED 0x00000002
-#define RNDIS_DF_RAW_DATA 0x00000004
-
-/*
- * Remote NDIS medium types.
- */
-#define RNDIS_MEDIUM_802_3 0x00000000
-#define RNDIS_MEDIUM_802_5 0x00000001
-#define RNDIS_MEDIUM_FDDI 0x00000002
-#define RNDIS_MEDIUM_WAN 0x00000003
-#define RNDIS_MEDIUM_LOCAL_TALK 0x00000004
-#define RNDIS_MEDIUM_ARCNET_RAW 0x00000006
-#define RNDIS_MEDIUM_ARCNET_878_2 0x00000007
-#define RNDIS_MEDIUM_ATM 0x00000008
-#define RNDIS_MEDIUM_WIRELESS_WAN 0x00000009
-#define RNDIS_MEDIUM_IRDA 0x0000000a
-#define RNDIS_MEDIUM_CO_WAN 0x0000000b
-/* Not a real medium, defined as an upper bound */
-#define RNDIS_MEDIUM_MAX 0x0000000d
-
-/*
- * Remote NDIS medium connection states.
- */
-#define RNDIS_MEDIA_STATE_CONNECTED 0x00000000
-#define RNDIS_MEDIA_STATE_DISCONNECTED 0x00000001
-
-/*
- * Remote NDIS version numbers
- */
-#define RNDIS_MAJOR_VERSION 0x00000001
-#define RNDIS_MINOR_VERSION 0x00000000
-
-/*
- * Remote NDIS offload parameters
- */
-#define RNDIS_OBJECT_TYPE_DEFAULT 0x80
-
-#define RNDIS_OFFLOAD_PARAMS_REVISION_3 3
-#define RNDIS_OFFLOAD_PARAMS_NO_CHANGE 0
-#define RNDIS_OFFLOAD_PARAMS_LSOV2_DISABLED 1
-#define RNDIS_OFFLOAD_PARAMS_LSOV2_ENABLED 2
-#define RNDIS_OFFLOAD_PARAMS_LSOV1_ENABLED 2
-#define RNDIS_OFFLOAD_PARAMS_RSC_DISABLED 1
-#define RNDIS_OFFLOAD_PARAMS_RSC_ENABLED 2
-#define RNDIS_OFFLOAD_PARAMS_TX_RX_DISABLED 1
-#define RNDIS_OFFLOAD_PARAMS_TX_ENABLED_RX_DISABLED 2
-#define RNDIS_OFFLOAD_PARAMS_RX_ENABLED_TX_DISABLED 3
-#define RNDIS_OFFLOAD_PARAMS_TX_RX_ENABLED 4
-
-#define RNDIS_TCP_LARGE_SEND_OFFLOAD_V2_TYPE 1
-#define RNDIS_TCP_LARGE_SEND_OFFLOAD_IPV4 0
-#define RNDIS_TCP_LARGE_SEND_OFFLOAD_IPV6 1
-
-#define RNDIS_OID_TCP_OFFLOAD_CURRENT_CONFIG 0xFC01020B /* query only */
-#define RNDIS_OID_TCP_OFFLOAD_PARAMS 0xFC01020C /* set only */
-#define RNDIS_OID_TCP_OFFLOAD_HARDWARE_CAPS 0xFC01020D/* query only */
-#define RNDIS_OID_TCPCON_OFFLOAD_CURRENT_CONFIG 0xFC01020E /* query only */
-#define RNDIS_OID_TCPCON_OFFLOAD_HARDWARE_CAPS 0xFC01020F /* query */
-#define RNDIS_OID_OFFLOAD_ENCAPSULATION 0x0101010A /* set/query */
-
-/*
- * NdisInitialize message
- */
-struct rndis_init_req {
- /* RNDIS request ID */
- uint32_t request_id;
- uint32_t major_version;
- uint32_t minor_version;
- uint32_t max_xfer_size;
-};
-
-/*
- * Response to NdisInitialize
- */
-struct rndis_init_comp {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS status */
- uint32_t status;
- uint32_t major_version;
- uint32_t minor_version;
- uint32_t device_flags;
- /* RNDIS medium */
- uint32_t medium;
- uint32_t max_pkts_per_msg;
- uint32_t max_xfer_size;
- uint32_t pkt_align_factor;
- uint32_t af_list_offset;
- uint32_t af_list_size;
-};
-
-/*
- * Call manager devices only: Information about an address family
- * supported by the device is appended to the response to NdisInitialize.
- */
-struct rndis_co_address_family {
- /* RNDIS AF */
- uint32_t address_family;
- uint32_t major_version;
- uint32_t minor_version;
-};
-
-/*
- * NdisHalt message
- */
-struct rndis_halt_req {
- /* RNDIS request ID */
- uint32_t request_id;
-};
-
-/*
- * NdisQueryRequest message
- */
-struct rndis_query_req {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS OID */
- uint32_t oid;
- uint32_t info_buffer_length;
- uint32_t info_buffer_offset;
- /* RNDIS handle */
- uint32_t device_vc_handle;
-};
-
-/*
- * Response to NdisQueryRequest
- */
-struct rndis_query_comp {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS status */
- uint32_t status;
- uint32_t info_buffer_length;
- uint32_t info_buffer_offset;
-};
-
-/*
- * NdisSetRequest message
- */
-struct rndis_set_req {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS OID */
- uint32_t oid;
- uint32_t info_buffer_length;
- uint32_t info_buffer_offset;
- /* RNDIS handle */
- uint32_t device_vc_handle;
-};
-
-/*
- * Response to NdisSetRequest
- */
-struct rndis_set_comp {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS status */
- uint32_t status;
-};
-
-/*
- * NdisReset message
- */
-struct rndis_reset_req {
- uint32_t reserved;
-};
-
-/*
- * Response to NdisReset
- */
-struct rndis_reset_comp {
- /* RNDIS status */
- uint32_t status;
- uint32_t addressing_reset;
-};
-
-/*
- * NdisMIndicateStatus message
- */
-struct rndis_indicate_status {
- /* RNDIS status */
- uint32_t status;
- uint32_t status_buf_length;
- uint32_t status_buf_offset;
-};
-
-/*
- * Diagnostic information passed as the status buffer in
- * rndis_indicate_status messages signifying error conditions.
- */
-struct rndis_diagnostic_info {
- /* RNDIS status */
- uint32_t diag_status;
- uint32_t error_offset;
-};
-
-/*
- * NdisKeepAlive message
- */
-struct rndis_keepalive_req {
- /* RNDIS request ID */
- uint32_t request_id;
-};
-
-/*
- * Response to NdisKeepAlive
- */
-struct rndis_keepalive_comp {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS status */
- uint32_t status;
-};
-
-/*
- * Data message. All offset fields contain byte offsets from the
- * beginning of the rndis_pkt structure. All length fields are in
- * bytes. VcHandle is set to 0 for connectionless data, otherwise
- * it contains the VC handle.
- */
-struct rndis_pkt {
- uint32_t data_offset;
- uint32_t data_length;
- uint32_t oob_data_offset;
- uint32_t oob_data_length;
- uint32_t num_oob_data_elements;
- uint32_t pkt_info_offset;
- uint32_t pkt_info_length;
- /* RNDIS handle */
- uint32_t vc_handle;
- uint32_t reserved;
-};
-
-struct rndis_pkt_ex {
- uint32_t data_offset;
- uint32_t data_length;
- uint32_t oob_data_offset;
- uint32_t oob_data_length;
- uint32_t num_oob_data_elements;
- uint32_t pkt_info_offset;
- uint32_t pkt_info_length;
- /* RNDIS handle */
- uint32_t vc_handle;
- uint32_t reserved;
- uint64_t data_buf_id;
- uint32_t data_buf_offset;
- uint64_t next_header_buf_id;
- uint32_t next_header_byte_offset;
- uint32_t next_header_byte_count;
-};
-
-/*
- * Optional Out of Band data associated with a Data message.
- */
-struct rndis_oobd {
- uint32_t size;
- /* RNDIS class ID */
- uint32_t type;
- uint32_t class_info_offset;
-};
-
-/*
- * Packet extension field contents associated with a Data message.
- */
-struct rndis_pkt_info {
- uint32_t size;
- uint32_t type;
- uint32_t pkt_info_offset;
-};
-
-enum ndis_pkt_info_type {
- tcpip_chksum_info,
- ipsec_info,
- tcp_large_send_info,
- classification_handle_info,
- ndis_reserved,
- sgl_info,
- ieee_8021q_info,
- original_pkt_info,
- pkt_cancel_id,
- original_netbuf_list,
- cached_netbuf_list,
- short_pkt_padding_info,
- max_perpkt_info
-};
-
struct ndis_8021q_info {
union {
struct {
@@ -706,269 +143,13 @@ struct rndis_tcp_tso_info {
};
};
-#define RNDIS_VLAN_PPI_SIZE (sizeof(struct rndis_pkt_info) + \
+#define RNDIS_VLAN_PPI_SIZE (sizeof(struct rndis_pktinfo) + \
sizeof(struct ndis_8021q_info))
-#define RNDIS_CSUM_PPI_SIZE (sizeof(struct rndis_pkt_info) + \
+#define RNDIS_CSUM_PPI_SIZE (sizeof(struct rndis_pktinfo) + \
sizeof(struct rndis_tcp_ip_csum_info))
-#define RNDIS_TSO_PPI_SIZE (sizeof(struct rndis_pkt_info) + \
+#define RNDIS_TSO_PPI_SIZE (sizeof(struct rndis_pktinfo) + \
sizeof(struct rndis_tcp_tso_info))
-/*
- * Format of Information buffer passed in a SetRequest for the OID
- * OID_GEN_RNDIS_CONFIG_PARAMETER.
- */
-struct rndis_config_param_info {
- uint32_t name_offset;
- uint32_t name_length;
- uint32_t param_type;
- uint32_t value_offset;
- uint32_t value_length;
-};
-
-/*
- * Values for ParameterType in rndis_config_param_info
- */
-#define RNDIS_CONFIG_PARAM_TYPE_INTEGER 0
-#define RNDIS_CONFIG_PARAM_TYPE_STRING 2
-
-
-/*
- * CONDIS Miniport messages for connection oriented devices
- * that do not implement a call manager.
- */
-
-/*
- * CoNdisMiniportCreateVc message
- */
-struct rcondis_mp_create_vc {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS handle */
- uint32_t ndis_vc_handle;
-};
-
-/*
- * Response to CoNdisMiniportCreateVc
- */
-struct rcondis_mp_create_vc_comp {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS handle */
- uint32_t device_vc_handle;
- /* RNDIS status */
- uint32_t status;
-};
-
-/*
- * CoNdisMiniportDeleteVc message
- */
-struct rcondis_mp_delete_vc {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS handle */
- uint32_t device_vc_handle;
-};
-
-/*
- * Response to CoNdisMiniportDeleteVc
- */
-struct rcondis_mp_delete_vc_comp {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS status */
- uint32_t status;
-};
-
-/*
- * CoNdisMiniportQueryRequest message
- */
-struct rcondis_mp_query_req {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS request type */
- uint32_t request_type;
- /* RNDIS OID */
- uint32_t oid;
- /* RNDIS handle */
- uint32_t device_vc_handle;
- uint32_t info_buf_length;
- uint32_t info_buf_offset;
-};
-
-/*
- * CoNdisMiniportSetRequest message
- */
-struct rcondis_mp_set_req {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS request type */
- uint32_t request_type;
- /* RNDIS OID */
- uint32_t oid;
- /* RNDIS handle */
- uint32_t device_vc_handle;
- uint32_t info_buf_length;
- uint32_t info_buf_offset;
-};
-
-/*
- * CoNdisIndicateStatus message
- */
-struct rcondis_indicate_status {
- /* RNDIS handle */
- uint32_t ndis_vc_handle;
- /* RNDIS status */
- uint32_t status;
- uint32_t status_buf_length;
- uint32_t status_buf_offset;
-};
-
-/*
- * CONDIS Call/VC parameters
- */
-
-struct rcondis_specific_params {
- uint32_t type;
- uint32_t length;
- uint32_t offset;
-};
-
-struct rcondis_media_params {
- uint32_t flags;
- uint32_t reserved1;
- uint32_t reserved2;
- struct rcondis_specific_params media_specific;
-};
-
-struct rndis_flowspec {
- uint32_t token_rate;
- uint32_t token_bucket_size;
- uint32_t peak_bandwidth;
- uint32_t latency;
- uint32_t delay_variation;
- uint32_t service_type;
- uint32_t max_sdu_size;
- uint32_t minimum_policed_size;
-};
-
-struct rcondis_call_manager_params {
- struct rndis_flowspec transmit;
- struct rndis_flowspec receive;
- struct rcondis_specific_params call_mgr_specific;
-};
-
-/*
- * CoNdisMiniportActivateVc message
- */
-struct rcondis_mp_activate_vc_req {
- /* RNDIS request ID */
- uint32_t request_id;
- uint32_t flags;
- /* RNDIS handle */
- uint32_t device_vc_handle;
- uint32_t media_params_offset;
- uint32_t media_params_length;
- uint32_t call_mgr_params_offset;
- uint32_t call_mgr_params_length;
-};
-
-/*
- * Response to CoNdisMiniportActivateVc
- */
-struct rcondis_mp_activate_vc_comp {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS status */
- uint32_t status;
-};
-
-/*
- * CoNdisMiniportDeactivateVc message
- */
-struct rcondis_mp_deactivate_vc_req {
- /* RNDIS request ID */
- uint32_t request_id;
- uint32_t flags;
- /* RNDIS handle */
- uint32_t device_vc_handle;
-};
-
-/*
- * Response to CoNdisMiniportDeactivateVc
- */
-struct rcondis_mp_deactivate_vc_comp {
- /* RNDIS request ID */
- uint32_t request_id;
- /* RNDIS status */
- uint32_t status;
-};
-
-/*
- * Container with all of the RNDIS messages
- */
-union rndis_msg_cont {
- struct rndis_pkt pkt;
- struct rndis_init_req init_req;
- struct rndis_halt_req halt_req;
- struct rndis_query_req query_req;
- struct rndis_set_req set_req;
- struct rndis_reset_req reset_req;
- struct rndis_keepalive_req keepalive_req;
- struct rndis_indicate_status indicate_status;
- struct rndis_init_comp init_comp;
- struct rndis_query_comp query_comp;
- struct rndis_set_comp set_comp;
- struct rndis_reset_comp reset_comp;
- struct rndis_keepalive_comp keepalive_comp;
- struct rcondis_mp_create_vc co_mp_create_vc;
- struct rcondis_mp_delete_vc co_mp_delete_vc;
- struct rcondis_indicate_status co_mp_status;
- struct rcondis_mp_activate_vc_req co_mp_activate_vc;
- struct rcondis_mp_deactivate_vc_req co_mp_deactivate_vc;
- struct rcondis_mp_create_vc_comp co_mp_create_vc_comp;
- struct rcondis_mp_delete_vc_comp co_mp_delete_vc_comp;
- struct rcondis_mp_activate_vc_comp co_mp_activate_vc_comp;
- struct rcondis_mp_deactivate_vc_comp co_mp_deactivate_vc_comp;
- struct rndis_pkt_ex pkt_ex;
-};
-
-/*
- * Remote NDIS message format
- */
-struct rndis {
- uint32_t msg_type;
-
- /*
- * Total length of this message, from the beginning
- * of the struct, in bytes.
- */
- uint32_t msg_len;
-
- /* Actual message */
- union rndis_msg_cont msg;
-};
-
-/*
- * get the size of an RNDIS message. Pass in the message type,
- * rndis_set_req, rndis_packet for example
- */
-#define RNDIS_HEADER_SIZE 8
-#define RNDIS_MESSAGE_SIZE(message) \
- (sizeof(message) + RNDIS_HEADER_SIZE)
-
-#define NDIS_PACKET_TYPE_DIRECTED 0x00000001
-#define NDIS_PACKET_TYPE_MULTICAST 0x00000002
-#define NDIS_PACKET_TYPE_ALL_MULTICAST 0x00000004
-#define NDIS_PACKET_TYPE_BROADCAST 0x00000008
-#define NDIS_PACKET_TYPE_SOURCE_ROUTING 0x00000010
-#define NDIS_PACKET_TYPE_PROMISCUOUS 0x00000020
-#define NDIS_PACKET_TYPE_SMT 0x00000040
-#define NDIS_PACKET_TYPE_ALL_LOCAL 0x00000080
-#define NDIS_PACKET_TYPE_GROUP 0x00000100
-#define NDIS_PACKET_TYPE_ALL_FUNCTIONAL 0x00000200
-#define NDIS_PACKET_TYPE_FUNCTIONAL 0x00000400
-#define NDIS_PACKET_TYPE_MAC_FRAME 0x00000800
-
#endif /* _DEV_PV_RNDISREG_H_ */