diff options
author | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2006-05-10 19:21:58 +0000 |
---|---|---|
committer | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2006-05-10 19:21:58 +0000 |
commit | a9f755239834c0175117b1347fc639e0d0272641 (patch) | |
tree | 9125084f61162afb6596cdd758a7f3a1ea9f29bb | |
parent | 5caaa554ae499b1e90cb1251cc70b81a2ad8f152 (diff) | |
download | slirp-0.8.2.zip slirp-0.8.2.tar.gz slirp-0.8.2.tar.bz2 |
suppressed unaligned accessesv0.8.2release_0_8_2
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1911 c046a42c-6fe2-441c-8c8c-71466251a162
-rw-r--r-- | if.c | 4 | ||||
-rw-r--r-- | slirp.c | 9 |
2 files changed, 7 insertions, 6 deletions
@@ -47,8 +47,8 @@ void if_init() if_maxlinkhdr = 40; #endif #else - /* 14 for ethernet + 40 */ - if_maxlinkhdr = 14 + 40; + /* 2 for alignment, 14 for ethernet, 40 for TCP/IP */ + if_maxlinkhdr = 2 + 14 + 40; #endif if_mtu = 1500; if_mru = 1500; @@ -610,11 +610,12 @@ void slirp_input(const uint8_t *pkt, int pkt_len) m = m_get(); if (!m) return; - m->m_len = pkt_len; - memcpy(m->m_data, pkt, pkt_len); + /* Note: we add to align the IP header */ + m->m_len = pkt_len + 2; + memcpy(m->m_data + 2, pkt, pkt_len); - m->m_data += ETH_HLEN; - m->m_len -= ETH_HLEN; + m->m_data += 2 + ETH_HLEN; + m->m_len -= 2 + ETH_HLEN; ip_input(m); break; |