mirror of
https://passt.top/passt
synced 2025-06-12 10:35:34 +02:00
Use typing to reduce chances of IPv4 endianness errors
We recently corrected some errors handling the endianness of IPv4 addresses. These are very easy errors to make since although we mostly store them in network endianness, we sometimes need to manipulate them in host endianness. To reduce the chances of making such mistakes again, change to always using a (struct in_addr) instead of a bare in_addr_t or uint32_t to store network endian addresses. This makes it harder to accidentally do arithmetic or comparisons on such addresses as if they were host endian. We introduce a number of IN4_IS_ADDR_*() helpers to make it easier to directly work with struct in_addr values. This has the additional benefit of making the IPv4 and IPv6 paths more visually similar. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
This commit is contained in:
parent
dd3470d9a9
commit
7c7b68dbe0
14 changed files with 113 additions and 100 deletions
12
passt.h
12
passt.h
|
@ -105,12 +105,12 @@ enum passt_modes {
|
|||
* @dns_fwd: Address forwarded (UDP) to first IPv4 DNS, network order
|
||||
*/
|
||||
struct ip4_ctx {
|
||||
uint32_t addr;
|
||||
uint32_t addr_seen;
|
||||
struct in_addr addr;
|
||||
struct in_addr addr_seen;
|
||||
int prefix_len;
|
||||
uint32_t gw;
|
||||
uint32_t dns[MAXNS + 1];
|
||||
uint32_t dns_fwd;
|
||||
struct in_addr gw;
|
||||
struct in_addr dns[MAXNS + 1];
|
||||
struct in_addr dns_fwd;
|
||||
};
|
||||
|
||||
/**
|
||||
|
@ -248,6 +248,6 @@ struct ctx {
|
|||
};
|
||||
|
||||
void proto_update_l2_buf(const unsigned char *eth_d, const unsigned char *eth_s,
|
||||
const uint32_t *ip_da);
|
||||
const struct in_addr *ip_da);
|
||||
|
||||
#endif /* PASST_H */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue