Bladeren bron

[iobuf] Add iob_disown() and use it where it simplifies code

There are many functions that take ownership of the I/O buffer they
are passed as a parameter.  The caller should not retain a pointer to
the I/O buffer.  Use iob_disown() to automatically nullify the
caller's pointer, e.g.:

    xfer_deliver_iob ( xfer, iob_disown ( iobuf ) );

This will ensure that iobuf is set to NULL for any code after the call
to xfer_deliver_iob().

iob_disown() is currently used only in places where it simplifies the
code, by avoiding an extra line explicitly setting the I/O buffer
pointer to NULL.  It should ideally be used with each call to any
function that takes ownership of an I/O buffer.  (The SSA
optimisations will ensure that use of iob_disown() gets optimised away
in cases where the caller makes no further use of the I/O buffer
pointer anyway.)

If gcc ever introduces an __attribute__((free)), indicating that use
of a function argument after a function call should generate a
warning, then we should use this to identify all applicable function
call sites, and add iob_disown() as necessary.
tags/v0.9.7
Michael Brown 16 jaren geleden
bovenliggende
commit
dbe84c5aad
8 gewijzigde bestanden met toevoegingen van 31 en 18 verwijderingen
  1. 1
    2
      src/arch/i386/drivers/net/undinet.c
  2. 20
    0
      src/include/gpxe/iobuf.h
  3. 1
    2
      src/interface/efi/efi_snp.c
  4. 2
    2
      src/net/arp.c
  5. 1
    2
      src/net/tcp/http.c
  6. 1
    2
      src/net/udp.c
  7. 2
    3
      src/net/udp/dhcp.c
  8. 3
    5
      src/net/udp/tftp.c

+ 1
- 2
src/arch/i386/drivers/net/undinet.c Bestand weergeven

@@ -482,8 +482,7 @@ static void undinet_poll ( struct net_device *netdev ) {
482 482
 					 undi_isr.Frame.offset, frag_len );
483 483
 			if ( iob_len ( iobuf ) == len ) {
484 484
 				/* Whole packet received; deliver it */
485
-				netdev_rx ( netdev, iobuf );
486
-				iobuf = NULL;
485
+				netdev_rx ( netdev, iob_disown ( iobuf ) );
487 486
 				/* Etherboot 5.4 fails to return all packets
488 487
 				 * under mild load; pretend it retriggered.
489 488
 				 */

+ 20
- 0
src/include/gpxe/iobuf.h Bestand weergeven

@@ -199,6 +199,26 @@ static inline void iob_populate ( struct io_buffer *iobuf,
199 199
 	iobuf->end = ( data + max_len );
200 200
 }
201 201
 
202
+/**
203
+ * Disown an I/O buffer
204
+ *
205
+ * @v iobuf	I/O buffer
206
+ *
207
+ * There are many functions that take ownership of the I/O buffer they
208
+ * are passed as a parameter.  The caller should not retain a pointer
209
+ * to the I/O buffer.  Use iob_disown() to automatically nullify the
210
+ * caller's pointer, e.g.:
211
+ *
212
+ *     xfer_deliver_iob ( xfer, iob_disown ( iobuf ) );
213
+ *
214
+ * This will ensure that iobuf is set to NULL for any code after the
215
+ * call to xfer_deliver_iob().
216
+ */
217
+#define iob_disown( iobuf ) ( {				\
218
+	struct io_buffer *__iobuf = (iobuf);		\
219
+	(iobuf) = NULL;					\
220
+	__iobuf; } )
221
+
202 222
 extern struct io_buffer * __malloc alloc_iob ( size_t len );
203 223
 extern void free_iob ( struct io_buffer *iobuf );
204 224
 extern void iob_pad ( struct io_buffer *iobuf, size_t min_len );

+ 1
- 2
src/interface/efi/efi_snp.c Bestand weergeven

@@ -602,10 +602,9 @@ efi_snp_transmit ( EFI_SIMPLE_NETWORK_PROTOCOL *snp,
602 602
 	}
603 603
 
604 604
 	/* Transmit packet */
605
-	if ( ( rc = netdev_tx ( snpdev->netdev, iobuf ) ) != 0 ) {
605
+	if ( ( rc = netdev_tx ( snpdev->netdev, iob_disown ( iobuf ) ) ) != 0){
606 606
 		DBGC ( snpdev, "SNPDEV %p TX could not transmit: %s\n",
607 607
 		       snpdev, strerror ( rc ) );
608
-		iobuf = NULL;
609 608
 		efirc = RC_TO_EFIRC ( rc );
610 609
 		goto err_tx;
611 610
 	}

+ 2
- 2
src/net/arp.c Bestand weergeven

@@ -265,8 +265,8 @@ static int arp_rx ( struct io_buffer *iobuf, struct net_device *netdev,
265 265
 	memcpy ( arp_sender_ha ( arphdr ), netdev->ll_addr, arphdr->ar_hln );
266 266
 
267 267
 	/* Send reply */
268
-	net_tx ( iobuf, netdev, &arp_protocol, arp_target_ha (arphdr ) );
269
-	iobuf = NULL;
268
+	net_tx ( iob_disown ( iobuf ), netdev, &arp_protocol,
269
+		 arp_target_ha ( arphdr ) );
270 270
 
271 271
  done:
272 272
 	free_iob ( iobuf );

+ 1
- 2
src/net/tcp/http.c Bestand weergeven

@@ -340,8 +340,7 @@ static int http_socket_deliver_iob ( struct xfer_interface *socket,
340 340
 			/* Once we're into the data phase, just fill
341 341
 			 * the data buffer
342 342
 			 */
343
-			rc = http_rx_data ( http, iobuf );
344
-			iobuf = NULL;
343
+			rc = http_rx_data ( http, iob_disown ( iobuf ) );
345 344
 			goto done;
346 345
 		case HTTP_RX_RESPONSE:
347 346
 		case HTTP_RX_HEADER:

+ 1
- 2
src/net/udp.c Bestand weergeven

@@ -328,8 +328,7 @@ static int udp_rx ( struct io_buffer *iobuf, struct sockaddr_tcpip *st_src,
328 328
 	memset ( &meta, 0, sizeof ( meta ) );
329 329
 	meta.src = ( struct sockaddr * ) st_src;
330 330
 	meta.dest = ( struct sockaddr * ) st_dest;
331
-	rc = xfer_deliver_iob_meta ( &udp->xfer, iobuf, &meta );
332
-	iobuf = NULL;
331
+	rc = xfer_deliver_iob_meta ( &udp->xfer, iob_disown ( iobuf ), &meta );
333 332
 
334 333
  done:
335 334
 	free_iob ( iobuf );

+ 2
- 3
src/net/udp/dhcp.c Bestand weergeven

@@ -976,9 +976,8 @@ static int dhcp_tx ( struct dhcp_session *dhcp ) {
976 976
 
977 977
 	/* Transmit the packet */
978 978
 	iob_put ( iobuf, dhcppkt.len );
979
-	rc = xfer_deliver_iob_meta ( &dhcp->xfer, iobuf, &meta );
980
-	iobuf = NULL;
981
-	if ( rc != 0 ) {
979
+	if ( ( rc = xfer_deliver_iob_meta ( &dhcp->xfer, iob_disown ( iobuf ),
980
+					    &meta ) ) != 0 ) {
982 981
 		DBGC ( dhcp, "DHCP %p could not transmit UDP packet: %s\n",
983 982
 		       dhcp, strerror ( rc ) );
984 983
 		goto done;

+ 3
- 5
src/net/udp/tftp.c Bestand weergeven

@@ -763,9 +763,8 @@ static int tftp_rx_data ( struct tftp_request *tftp,
763 763
 	memset ( &meta, 0, sizeof ( meta ) );
764 764
 	meta.whence = SEEK_SET;
765 765
 	meta.offset = offset;
766
-	rc = xfer_deliver_iob_meta ( &tftp->xfer, iobuf, &meta );
767
-	iobuf = NULL;
768
-	if ( rc != 0 ) {
766
+	if ( ( rc = xfer_deliver_iob_meta ( &tftp->xfer, iob_disown ( iobuf ),
767
+					    &meta ) ) != 0 ) {
769 768
 		DBGC ( tftp, "TFTP %p could not deliver data: %s\n",
770 769
 		       tftp, strerror ( rc ) );
771 770
 		goto done;
@@ -887,8 +886,7 @@ static int tftp_rx ( struct tftp_request *tftp,
887 886
 		rc = tftp_rx_oack ( tftp, iobuf->data, len );
888 887
 		break;
889 888
 	case htons ( TFTP_DATA ):
890
-		rc = tftp_rx_data ( tftp, iobuf );
891
-		iobuf = NULL;
889
+		rc = tftp_rx_data ( tftp, iob_disown ( iobuf ) );
892 890
 		break;
893 891
 	case htons ( TFTP_ERROR ):
894 892
 		rc = tftp_rx_error ( tftp, iobuf->data, len );

Laden…
Annuleren
Opslaan