123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- #ifndef _GPXE_TCPIP_H
- #define _GPXE_TCPIP_H
-
- /** @file
- *
- * Transport-network layer interface
- *
- */
-
- #include <stdint.h>
- #include <gpxe/socket.h>
- #include <gpxe/in.h>
- #include <gpxe/tables.h>
-
- struct io_buffer;
- struct net_device;
-
- /** Empty checksum value
- *
- * This is the TCP/IP checksum over a zero-length block of data.
- */
- #define TCPIP_EMPTY_CSUM 0xffff
-
- /**
- * TCP/IP socket address
- *
- * This contains the fields common to socket addresses for all TCP/IP
- * address families.
- */
- struct sockaddr_tcpip {
- /** Socket address family (part of struct @c sockaddr) */
- sa_family_t st_family;
- /** TCP/IP port */
- uint16_t st_port;
- /** Padding
- *
- * This ensures that a struct @c sockaddr_tcpip is large
- * enough to hold a socket address for any TCP/IP address
- * family.
- */
- char pad[ sizeof ( struct sockaddr ) -
- ( sizeof ( sa_family_t ) + sizeof ( uint16_t ) ) ];
- } __attribute__ (( may_alias ));
-
- /**
- * A transport-layer protocol of the TCP/IP stack (eg. UDP, TCP, etc)
- */
- struct tcpip_protocol {
- /** Protocol name */
- const char *name;
- /**
- * Process received packet
- *
- * @v iobuf I/O buffer
- * @v st_src Partially-filled source address
- * @v st_dest Partially-filled destination address
- * @v pshdr_csum Pseudo-header checksum
- * @ret rc Return status code
- *
- * This method takes ownership of the I/O buffer.
- */
- int ( * rx ) ( struct io_buffer *iobuf, struct sockaddr_tcpip *st_src,
- struct sockaddr_tcpip *st_dest, uint16_t pshdr_csum );
- /**
- * Transport-layer protocol number
- *
- * This is a constant of the type IP_XXX
- */
- uint8_t tcpip_proto;
- };
-
- /**
- * A network-layer protocol of the TCP/IP stack (eg. IPV4, IPv6, etc)
- */
- struct tcpip_net_protocol {
- /** Protocol name */
- const char *name;
- /** Network address family */
- sa_family_t sa_family;
- /**
- * Transmit packet
- *
- * @v iobuf I/O buffer
- * @v tcpip_protocol Transport-layer protocol
- * @v st_src Source address, or NULL to use default
- * @v st_dest Destination address
- * @v netdev Network device (or NULL to route automatically)
- * @v trans_csum Transport-layer checksum to complete, or NULL
- * @ret rc Return status code
- *
- * This function takes ownership of the I/O buffer.
- */
- int ( * tx ) ( struct io_buffer *iobuf,
- struct tcpip_protocol *tcpip_protocol,
- struct sockaddr_tcpip *st_src,
- struct sockaddr_tcpip *st_dest,
- struct net_device *netdev,
- uint16_t *trans_csum );
- };
-
- /** Declare a TCP/IP transport-layer protocol */
- #define __tcpip_protocol \
- __table ( struct tcpip_protocol, tcpip_protocols, 01 )
-
- /** Declare a TCP/IP network-layer protocol */
- #define __tcpip_net_protocol \
- __table ( struct tcpip_net_protocol, tcpip_net_protocols, 01 )
-
- extern int tcpip_rx ( struct io_buffer *iobuf, uint8_t tcpip_proto,
- struct sockaddr_tcpip *st_src,
- struct sockaddr_tcpip *st_dest, uint16_t pshdr_csum );
- extern int tcpip_tx ( struct io_buffer *iobuf, struct tcpip_protocol *tcpip,
- struct sockaddr_tcpip *st_src,
- struct sockaddr_tcpip *st_dest,
- struct net_device *netdev,
- uint16_t *trans_csum );
- extern uint16_t tcpip_continue_chksum ( uint16_t partial,
- const void *data, size_t len );
- extern uint16_t tcpip_chksum ( const void *data, size_t len );
-
- #endif /* _GPXE_TCPIP_H */
|