Browse Source

Tidy up debug messages

Move routing into a separate function
tags/v0.9.3
Michael Brown 18 years ago
parent
commit
285beeff7c
1 changed files with 38 additions and 42 deletions
  1. 38
    42
      src/net/ipv4.c

+ 38
- 42
src/net/ipv4.c View File

101
 }
101
 }
102
 
102
 
103
 /**
103
 /**
104
- * Dump IPv4 packet header
104
+ * Perform IPv4 routing
105
  *
105
  *
106
- * @v iphdr	IPv4 header
106
+ * @v dest		Final destination address
107
+ * @ret dest		Next hop destination address
108
+ * @ret miniroute	Routing table entry to use, or NULL if no route
107
  */
109
  */
108
-static void ipv4_dump ( struct iphdr *iphdr __unused ) {
110
+static struct ipv4_miniroute * ipv4_route ( struct in_addr *dest ) {
111
+	struct ipv4_miniroute *miniroute;
112
+	int local;
113
+	int has_gw;
109
 
114
 
110
-	DBG ( "IP4 %p transmitting %p+%d ident %d protocol %d header-csum %x\n",
111
-		&ipv4_protocol, iphdr, ntohs ( iphdr->len ), ntohs ( iphdr->ident ),
112
-		iphdr->protocol, ntohs ( iphdr->chksum ) );
113
-	DBG ( "src %s, dest %s\n", inet_ntoa ( iphdr->src ), inet_ntoa ( iphdr->dest ) );
115
+	list_for_each_entry ( miniroute, &miniroutes, list ) {
116
+		local = ( ( ( dest->s_addr ^ miniroute->address.s_addr )
117
+			    & miniroute->netmask.s_addr ) == 0 );
118
+		has_gw = ( miniroute->gateway.s_addr != INADDR_NONE );
119
+		if ( local || has_gw ) {
120
+			if ( ! local )
121
+				*dest = miniroute->gateway;
122
+			return miniroute;
123
+		}
124
+	}
125
+
126
+	return NULL;
114
 }
127
 }
115
 
128
 
116
 /**
129
 /**
280
 	int rc;
293
 	int rc;
281
 
294
 
282
 	/* Fill up the IP header, except source address */
295
 	/* Fill up the IP header, except source address */
283
-	iphdr->verhdrlen = ( IP_VER << 4 ) | ( sizeof ( *iphdr ) / 4 );
296
+	iphdr->verhdrlen = ( ( IP_VER << 4 ) | ( sizeof ( *iphdr ) / 4 ) );
284
 	iphdr->service = IP_TOS;
297
 	iphdr->service = IP_TOS;
285
 	iphdr->len = htons ( pkb_len ( pkb ) );	
298
 	iphdr->len = htons ( pkb_len ( pkb ) );	
286
-	iphdr->ident = htons ( next_ident++ );
299
+	iphdr->ident = htons ( ++next_ident );
287
 	iphdr->frags = 0;
300
 	iphdr->frags = 0;
288
 	iphdr->ttl = IP_TTL;
301
 	iphdr->ttl = IP_TTL;
289
 	iphdr->protocol = tcpip_protocol->tcpip_proto;
302
 	iphdr->protocol = tcpip_protocol->tcpip_proto;
290
-
291
-	/* Copy destination address */
303
+	iphdr->chksum = 0;
292
 	iphdr->dest = sin_dest->sin_addr;
304
 	iphdr->dest = sin_dest->sin_addr;
293
 
305
 
294
-	/**
295
-	 * All fields in the IP header filled in except the source network
296
-	 * address (which requires routing) and the header checksum (which
297
-	 * requires the source network address). As the pseudo header requires
298
-	 * the source address as well and the transport-layer checksum is
299
-	 * updated after routing.
300
-	 */
301
-
302
 	/* Use routing table to identify next hop and transmitting netdev */
306
 	/* Use routing table to identify next hop and transmitting netdev */
303
 	next_hop = iphdr->dest;
307
 	next_hop = iphdr->dest;
304
-	list_for_each_entry ( miniroute, &miniroutes, list ) {
305
-		int local, has_gw;
306
-
307
-		local = ( ( ( iphdr->dest.s_addr ^ miniroute->address.s_addr )
308
-			    & miniroute->netmask.s_addr ) == 0 );
309
-		has_gw = ( miniroute->gateway.s_addr != INADDR_NONE );
310
-		if ( local || has_gw ) {
311
-			netdev = miniroute->netdev;
312
-			iphdr->src = miniroute->address;
313
-			if ( ! local )
314
-				next_hop = miniroute->gateway;
315
-			break;
316
-		}
317
-	}
318
-	/* Abort if no network device identified */
319
-	if ( ! netdev ) {
308
+	miniroute = ipv4_route ( &next_hop );
309
+	if ( ! miniroute ) {
320
 		DBG ( "No route to %s\n", inet_ntoa ( iphdr->dest ) );
310
 		DBG ( "No route to %s\n", inet_ntoa ( iphdr->dest ) );
321
 		rc = -EHOSTUNREACH;
311
 		rc = -EHOSTUNREACH;
322
 		goto err;
312
 		goto err;
323
 	}
313
 	}
314
+	iphdr->src = miniroute->address;
315
+	netdev = miniroute->netdev;
324
 
316
 
325
 	/* Calculate the transport layer checksum */
317
 	/* Calculate the transport layer checksum */
326
-	if ( tcpip_protocol->csum_offset > 0 ) {
318
+	if ( tcpip_protocol->csum_offset > 0 )
327
 		ipv4_tx_csum ( pkb, tcpip_protocol );
319
 		ipv4_tx_csum ( pkb, tcpip_protocol );
328
-	}
329
 
320
 
330
 	/* Calculate header checksum, in network byte order */
321
 	/* Calculate header checksum, in network byte order */
331
-	iphdr->chksum = 0;
332
 	iphdr->chksum = tcpip_chksum ( iphdr, sizeof ( *iphdr ) );
322
 	iphdr->chksum = tcpip_chksum ( iphdr, sizeof ( *iphdr ) );
333
 
323
 
334
 	/* Print IP4 header for debugging */
324
 	/* Print IP4 header for debugging */
335
-	ipv4_dump ( iphdr );
325
+	DBG ( "IPv4 TX %s->", inet_ntoa ( iphdr->src ) );
326
+	DBG ( "%s len %d proto %d id %04x csum %04x\n",
327
+	      inet_ntoa ( iphdr->dest ), ntohs ( iphdr->len ), iphdr->protocol,
328
+	      ntohs ( iphdr->ident ), ntohs ( iphdr->chksum ) );
336
 
329
 
337
 	/* Determine link-layer destination address */
330
 	/* Determine link-layer destination address */
338
 	if ( next_hop.s_addr == INADDR_BROADCAST ) {
331
 	if ( next_hop.s_addr == INADDR_BROADCAST ) {
394
 	}
387
 	}
395
 
388
 
396
 	/* Print IP4 header for debugging */
389
 	/* Print IP4 header for debugging */
397
-	ipv4_dump ( iphdr );
390
+	DBG ( "IPv4 RX %s<-", inet_ntoa ( iphdr->dest ) );
391
+	DBG ( "%s len %d proto %d id %04x csum %04x\n",
392
+	      inet_ntoa ( iphdr->src ), ntohs ( iphdr->len ), iphdr->protocol,
393
+	      ntohs ( iphdr->ident ), ntohs ( iphdr->chksum ) );
398
 
394
 
399
 	/* Validate version and header length */
395
 	/* Validate version and header length */
400
 	if ( iphdr->verhdrlen != 0x45 ) {
396
 	if ( iphdr->verhdrlen != 0x45 ) {
414
 		DBG ( "Bad checksum %x\n", chksum );
410
 		DBG ( "Bad checksum %x\n", chksum );
415
 	}
411
 	}
416
 	/* Fragment reassembly */
412
 	/* Fragment reassembly */
417
-	if ( ( iphdr->frags & IP_MASK_MOREFRAGS ) || 
418
-	     ( ( iphdr->frags & IP_MASK_OFFSET ) != 0 ) ) {
413
+	if ( ( iphdr->frags & htons ( IP_MASK_MOREFRAGS ) ) || 
414
+	     ( ( iphdr->frags & htons ( IP_MASK_OFFSET ) ) != 0 ) ) {
419
 		/* Pass the fragment to the reassembler ipv4_ressable() which
415
 		/* Pass the fragment to the reassembler ipv4_ressable() which
420
 		 * either returns a fully reassembled packet buffer or NULL.
416
 		 * either returns a fully reassembled packet buffer or NULL.
421
 		 */
417
 		 */

Loading…
Cancel
Save