aboutgitcodebugslistschat
path: root/tap.h
diff options
context:
space:
mode:
Diffstat (limited to 'tap.h')
-rw-r--r--tap.h96
1 files changed, 31 insertions, 65 deletions
diff --git a/tap.h b/tap.h
index 9303f8e..dfbd8b9 100644
--- a/tap.h
+++ b/tap.h
@@ -6,90 +6,61 @@
#ifndef TAP_H
#define TAP_H
-/*
- * TCP frame iovec array:
- * TCP_IOV_VNET vnet length
- * TCP_IOV_ETH ethernet header
- * TCP_IOV_IP IP (v4/v6) header
- * TCP_IOV_PAYLOAD IP payload (TCP header + data)
- * TCP_IOV_NUM is the number of entries in the iovec array
- */
-#define TCP_IOV_VNET 0
-#define TCP_IOV_ETH 1
-#define TCP_IOV_IP 2
-#define TCP_IOV_PAYLOAD 3
-#define TCP_IOV_NUM 4
+#define ETH_HDR_INIT(proto) { .h_proto = htons_constant(proto) }
/**
- * struct tap_hdr - L2 and tap specific headers
+ * struct tap_hdr - tap backend specific headers
* @vnet_len: Frame length (for qemu socket transport)
- * @eh: Ethernet header
*/
struct tap_hdr {
uint32_t vnet_len;
- struct ethhdr eh;
} __attribute__((packed));
-#define TAP_HDR_INIT(proto) { .eh.h_proto = htons_constant(proto) }
-
-static inline size_t tap_hdr_len_(const struct ctx *c)
-{
- if (c->mode == MODE_PASST)
- return sizeof(struct tap_hdr);
- else
- return sizeof(struct ethhdr);
-}
-
/**
- * tap_iov_base() - Find start of tap frame
+ * tap_hdr_iov() - struct iovec for a tap header
* @c: Execution context
- * @taph: Pointer to L2 header buffer
+ * @taph: Pointer to tap specific header buffer
*
- * Returns: pointer to the start of tap frame - suitable for an
- * iov_base to be passed to tap_send_frames())
+ * Returns: A struct iovec covering the correct portion of @taph to use as the
+ * tap specific header in the current configuration.
*/
-static inline void *tap_iov_base(const struct ctx *c, struct tap_hdr *taph)
+static inline struct iovec tap_hdr_iov(const struct ctx *c,
+ struct tap_hdr *thdr)
{
- return (char *)(taph + 1) - tap_hdr_len_(c);
+ return (struct iovec){
+ .iov_base = thdr,
+ .iov_len = c->mode == MODE_PASST ? sizeof(*thdr) : 0,
+ };
}
/**
- * tap_iov_len() - Finalize tap frame and return total length
- * @c: Execution context
- * @taph: Tap header to finalize
- * @plen: L2 payload length (excludes L2 and tap specific headers)
- *
- * Returns: length of the tap frame including L2 and tap specific
- * headers - suitable for an iov_len to be passed to
- * tap_send_frames()
+ * tap_hdr_update() - Update the tap specific header for a frame
+ * @taph: Tap specific header buffer to update
+ * @l2len: Frame length (including L2 headers)
*/
-static inline size_t tap_iov_len(const struct ctx *c, struct tap_hdr *taph,
- size_t plen)
+static inline void tap_hdr_update(struct tap_hdr *thdr, size_t l2len)
{
- if (c->mode == MODE_PASST)
- taph->vnet_len = htonl(plen + sizeof(taph->eh));
- return plen + tap_hdr_len_(c);
+ if (thdr)
+ thdr->vnet_len = htonl(l2len);
}
-struct in_addr tap_ip4_daddr(const struct ctx *c);
void tap_udp4_send(const struct ctx *c, struct in_addr src, in_port_t sport,
struct in_addr dst, in_port_t dport,
- const void *in, size_t len);
+ const void *in, size_t dlen);
void tap_icmp4_send(const struct ctx *c, struct in_addr src, struct in_addr dst,
- const void *in, size_t len);
+ const void *in, size_t l4len);
const struct in6_addr *tap_ip6_daddr(const struct ctx *c,
const struct in6_addr *src);
void tap_udp6_send(const struct ctx *c,
const struct in6_addr *src, in_port_t sport,
const struct in6_addr *dst, in_port_t dport,
- uint32_t flow, const void *in, size_t len);
+ uint32_t flow, void *in, size_t dlen);
void tap_icmp6_send(const struct ctx *c,
const struct in6_addr *src, const struct in6_addr *dst,
- const void *in, size_t len);
-int tap_send(const struct ctx *c, const void *data, size_t len);
-size_t tap_send_frames(const struct ctx *c, const struct iovec *iov, size_t n);
-size_t tap_send_iov(const struct ctx *c, struct iovec iov[][TCP_IOV_NUM],
- size_t n);
+ const void *in, size_t l4len);
+void tap_send_single(const struct ctx *c, const void *data, size_t l2len);
+size_t tap_send_frames(const struct ctx *c, const struct iovec *iov,
+ size_t bufs_per_frame, size_t nframes);
void eth_update_mac(struct ethhdr *eh,
const unsigned char *eth_d, const unsigned char *eth_s);
void tap_listen_handler(struct ctx *c, uint32_t events);
@@ -97,17 +68,12 @@ void tap_handler_pasta(struct ctx *c, uint32_t events,
const struct timespec *now);
void tap_handler_passt(struct ctx *c, uint32_t events,
const struct timespec *now);
+int tap_sock_unix_open(char *sock_path);
void tap_sock_reset(struct ctx *c);
-void tap_sock_update_buf(void *base, size_t size);
-void tap_sock_init(struct ctx *c);
-void pool_flush_all(void);
-void tap_handler_all(struct ctx *c, const struct timespec *now);
-
-void packet_add_do(struct pool *p, size_t len, const char *start,
- const char *func, int line);
-void packet_add_all_do(struct ctx *c, ssize_t len, char *p,
- const char *func, int line);
-#define packet_add_all(p, len, start) \
- packet_add_all_do(p, len, start, __func__, __LINE__)
+void tap_sock_update_pool(void *base, size_t size);
+void tap_backend_init(struct ctx *c);
+void tap_flush_pools(void);
+void tap_handler(struct ctx *c, const struct timespec *now);
+void tap_add_packet(struct ctx *c, ssize_t l2len, char *p);
#endif /* TAP_H */