fix access to possibly uninitialized variable in GW when receiving corrupted pkt

master
Andre Puschmann 6 years ago
parent f7bdfdc3a8
commit 759ab6341d

@ -219,11 +219,9 @@ void gw::add_mch_port(uint32_t lcid, uint32_t port)
/********************/ /********************/
void gw::run_thread() void gw::run_thread()
{ {
struct iphdr *ip_pkt;
struct ipv6hdr *ip6_pkt;
uint32 idx = 0; uint32 idx = 0;
int32 N_bytes; int32 N_bytes = 0;
uint16_t pkt_len;
srslte::byte_buffer_t *pdu = pool_allocate_blocking; srslte::byte_buffer_t *pdu = pool_allocate_blocking;
if (!pdu) { if (!pdu) {
gw_log->error("Fatal Error: Couldn't allocate PDU in run_thread().\n"); gw_log->error("Fatal Error: Couldn't allocate PDU in run_thread().\n");
@ -246,16 +244,19 @@ void gw::run_thread()
break; break;
} }
gw_log->debug("Read %d bytes from TUN fd=%d, idx=%d\n", N_bytes, tun_fd, idx); gw_log->debug("Read %d bytes from TUN fd=%d, idx=%d\n", N_bytes, tun_fd, idx);
if(N_bytes > 0) if (N_bytes > 0) {
{ struct iphdr *ip_pkt = (struct iphdr*)pdu->msg;
struct ipv6hdr *ip6_pkt = (struct ipv6hdr*)pdu->msg;
uint16_t pkt_len = 0;
pdu->N_bytes = idx + N_bytes; pdu->N_bytes = idx + N_bytes;
ip_pkt = (struct iphdr*)pdu->msg;
ip6_pkt = (struct ipv6hdr*)pdu->msg;
if (ip_pkt->version == 4 || ip_pkt->version == 6) { if (ip_pkt->version == 4 || ip_pkt->version == 6) {
if (ip_pkt->version == 4){ if (ip_pkt->version == 4){
pkt_len = ntohs(ip_pkt->tot_len); pkt_len = ntohs(ip_pkt->tot_len);
} else if (ip_pkt->version == 6){ } else if (ip_pkt->version == 6){
pkt_len = ntohs(ip6_pkt->payload_len)+40; pkt_len = ntohs(ip6_pkt->payload_len)+40;
} else {
gw_log->error_hex(pdu->msg, pdu->N_bytes, "Unsupported IP version. Dropping packet.\n");
continue;
} }
gw_log->debug("IPv%d packet total length: %d Bytes\n", ip_pkt->version, pkt_len); gw_log->debug("IPv%d packet total length: %d Bytes\n", ip_pkt->version, pkt_len);
// Check if entire packet was received // Check if entire packet was received

Loading…
Cancel
Save