diff options
| -rw-r--r-- | drivers/net/netconsole.c | 8 | ||||
| -rw-r--r-- | include/net.h | 3 | ||||
| -rw-r--r-- | net/net.c | 1 | 
3 files changed, 9 insertions, 3 deletions
| diff --git a/drivers/net/netconsole.c b/drivers/net/netconsole.c index 63ce73c81..dd7032af5 100644 --- a/drivers/net/netconsole.c +++ b/drivers/net/netconsole.c @@ -147,13 +147,17 @@ void NcStart(void)  	}  } -int nc_input_packet(uchar *pkt, unsigned dest, unsigned src, unsigned len) +int nc_input_packet(uchar *pkt, IPaddr_t src_ip, unsigned dest_port, +	unsigned src_port, unsigned len)  {  	int end, chunk; -	if (dest != nc_in_port || !len) +	if (dest_port != nc_in_port || !len)  		return 0; /* not for us */ +	if (src_ip != nc_ip && !is_broadcast(nc_ip)) +		return 0; /* not from our client */ +  	debug_cond(DEBUG_DEV_PKT, "input: \"%*.*s\"\n", len, len, pkt);  	if (input_size == sizeof(input_buffer)) diff --git a/include/net.h b/include/net.h index e193b7b60..35393366d 100644 --- a/include/net.h +++ b/include/net.h @@ -549,7 +549,8 @@ extern void NetReceive(uchar *, int);  #ifdef CONFIG_NETCONSOLE  void NcStart(void); -int nc_input_packet(uchar *pkt, unsigned dest, unsigned src, unsigned len); +int nc_input_packet(uchar *pkt, IPaddr_t src_ip, unsigned dest_port, +	unsigned src_port, unsigned len);  #endif  static inline __attribute__((always_inline)) int eth_is_on_demand_init(void) @@ -1161,6 +1161,7 @@ NetReceive(uchar *inpkt, int len)  #ifdef CONFIG_NETCONSOLE  		nc_input_packet((uchar *)ip + IP_UDP_HDR_SIZE, +					ntohl(ip->ip_src),  					ntohs(ip->udp_dst),  					ntohs(ip->udp_src),  					ntohs(ip->udp_len) - UDP_HDR_SIZE); |