summaryrefslogtreecommitdiff
path: root/sys/dev/pv/if_hvn.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/pv/if_hvn.c')
-rw-r--r--sys/dev/pv/if_hvn.c27
1 files changed, 12 insertions, 15 deletions
diff --git a/sys/dev/pv/if_hvn.c b/sys/dev/pv/if_hvn.c
index 3647a6f3506..bb316afe6b0 100644
--- a/sys/dev/pv/if_hvn.c
+++ b/sys/dev/pv/if_hvn.c
@@ -57,7 +57,7 @@
#include <dev/pv/hypervvar.h>
#include <dev/rndis.h>
-#include <dev/pv/rndisreg.h>
+#include <dev/pv/ndis.h>
#include <dev/pv/if_hvnreg.h>
#include <net/if.h>
@@ -86,8 +86,8 @@
#define HVN_RNDIS_CMPBUFSZ 512
#define HVN_RNDIS_MSG_LEN \
- (sizeof(struct rndis_packet_msg) + RNDIS_VLAN_PPI_SIZE + \
- RNDIS_CSUM_PPI_SIZE)
+ (sizeof(struct rndis_packet_msg) + NDIS_VLAN_INFO_SIZE + \
+ NDIS_RXCSUM_INFO_SIZE)
struct rndis_cmd {
uint32_t rc_id;
@@ -787,8 +787,8 @@ hvn_get_link_status(struct hvn_softc *sc)
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;
+ sc->sc_link_state = (state == NDIS_MEDIA_STATE_CONNECTED) ?
+ LINK_STATE_UP : LINK_STATE_DOWN;
}
int
@@ -1315,8 +1315,7 @@ hvn_rxeof(struct hvn_softc *sc, caddr_t buf, uint32_t len,
struct ifnet *ifp = &sc->sc_ac.ac_if;
struct rndis_packet_msg *pkt;
struct rndis_pktinfo *pi;
- struct rndis_tcp_ip_csum_info *csum;
- struct ndis_8021q_info *vlan;
+ uint32_t csum, vlan;
struct mbuf *m;
if (!(ifp->if_flags & IFF_RUNNING))
@@ -1359,20 +1358,18 @@ hvn_rxeof(struct hvn_softc *sc, caddr_t buf, uint32_t len,
}
switch (pi->rm_type) {
case NDIS_PKTINFO_TYPE_CSUM:
- csum = (struct rndis_tcp_ip_csum_info *)
- ((caddr_t)pi + pi->rm_size);
- if (csum->recv.ip_csum_succeeded)
+ memcpy(&csum, (caddr_t)pi + pi->rm_size, sizeof(csum));
+ if (csum & NDIS_RXCSUM_INFO_IPCS_OK)
m->m_pkthdr.csum_flags |= M_IPV4_CSUM_IN_OK;
- if (csum->recv.tcp_csum_succeeded)
+ if (csum & NDIS_RXCSUM_INFO_TCPCS_OK)
m->m_pkthdr.csum_flags |= M_TCP_CSUM_IN_OK;
- if (csum->recv.udp_csum_succeeded)
+ if (csum & NDIS_RXCSUM_INFO_UDPCS_OK)
m->m_pkthdr.csum_flags |= M_UDP_CSUM_IN_OK;
break;
case NDIS_PKTINFO_TYPE_VLAN:
- vlan = (struct ndis_8021q_info *)
- ((caddr_t)pi + pi->rm_size);
+ memcpy(&vlan, (caddr_t)pi + pi->rm_size, sizeof(vlan));
#if NVLAN > 0
- m->m_pkthdr.ether_vtag = vlan->vlan_id;
+ m->m_pkthdr.ether_vtag = vlan & 0xffff;
m->m_flags |= M_VLANTAG;
#endif
break;