net: socket: Change the protocol field for AF_PACKET sockets

In order to be compatible with Linux AF_PACKET socket calls, the
protocol field needs to be in network byte order.
So for example, if user wants to receive all packets, then the
protocol field needs to be set as "htons(ETH_P_ALL)".
See Linux manual page at
https://www.man7.org/linux/man-pages/man7/packet.7.html
for details.

Signed-off-by: Jukka Rissanen <jukka.rissanen@nordicsemi.no>
This commit is contained in:
Jukka Rissanen 2024-05-27 13:28:28 +03:00 committed by Carles Cufí
commit 99693bee5f
10 changed files with 40 additions and 24 deletions

View file

@ -405,7 +405,7 @@ static int set_up_recv_socket(enum net_sock_type socket_type)
};
int fd;
fd = zsock_socket(AF_PACKET, socket_type, ETH_P_IEEE802154);
fd = zsock_socket(AF_PACKET, socket_type, htons(ETH_P_IEEE802154));
if (fd < 0) {
NET_ERR("*** Failed to create recv socket : %d", errno);
return fd;
@ -697,7 +697,7 @@ static bool test_dgram_packet_sending(void *dst_sll, uint8_t dst_sll_halen, uint
}
NET_INFO("- Sending DGRAM packet via AF_PACKET socket");
fd = zsock_socket(AF_PACKET, SOCK_DGRAM, ETH_P_IEEE802154);
fd = zsock_socket(AF_PACKET, SOCK_DGRAM, htons(ETH_P_IEEE802154));
if (fd < 0) {
NET_ERR("*** Failed to create DGRAM socket : %d", errno);
goto reset_security;
@ -924,7 +924,7 @@ static bool test_raw_packet_sending(void)
NET_INFO("- Sending RAW packet via AF_PACKET socket");
fd = zsock_socket(AF_PACKET, SOCK_RAW, ETH_P_IEEE802154);
fd = zsock_socket(AF_PACKET, SOCK_RAW, htons(ETH_P_IEEE802154));
if (fd < 0) {
NET_ERR("*** Failed to create RAW socket : %d", errno);
goto out;
@ -1108,7 +1108,7 @@ static bool test_recv_and_send_ack_reply(struct ieee802154_pkt_test *t)
NET_INFO("- Sending ACK reply to a data packet");
fd = zsock_socket(AF_PACKET, SOCK_DGRAM, ETH_P_IEEE802154);
fd = zsock_socket(AF_PACKET, SOCK_DGRAM, htons(ETH_P_IEEE802154));
if (fd < 0) {
NET_ERR("*** Failed to create DGRAM socket : %d", errno);
goto out;

View file

@ -201,10 +201,10 @@ static void __test_packet_sockets(int *sock1, int *sock2)
zassert_not_null(ud.first, "1st Ethernet interface not found");
zassert_not_null(ud.second, "2nd Ethernet interface not found");
*sock1 = setup_socket(ud.first, SOCK_RAW, ETH_P_ALL);
*sock1 = setup_socket(ud.first, SOCK_RAW, htons(ETH_P_ALL));
zassert_true(*sock1 >= 0, "Cannot create 1st socket (%d)", *sock1);
*sock2 = setup_socket(ud.second, SOCK_RAW, ETH_P_ALL);
*sock2 = setup_socket(ud.second, SOCK_RAW, htons(ETH_P_ALL));
zassert_true(*sock2 >= 0, "Cannot create 2nd socket (%d)", *sock2);
ret = bind_socket(*sock1, ud.first);
@ -311,10 +311,10 @@ ZTEST(socket_packet, test_packet_sockets_dgram)
zassert_not_null(ud.first, "1st Ethernet interface not found");
zassert_not_null(ud.second, "2nd Ethernet interface not found");
sock1 = setup_socket(ud.first, SOCK_DGRAM, ETH_P_TSN);
sock1 = setup_socket(ud.first, SOCK_DGRAM, htons(ETH_P_TSN));
zassert_true(sock1 >= 0, "Cannot create 1st socket (%d)", sock1);
sock2 = setup_socket(ud.second, SOCK_DGRAM, ETH_P_TSN);
sock2 = setup_socket(ud.second, SOCK_DGRAM, htons(ETH_P_TSN));
zassert_true(sock2 >= 0, "Cannot create 2nd socket (%d)", sock2);
ret = bind_socket(sock1, ud.first);
@ -421,10 +421,10 @@ ZTEST(socket_packet, test_raw_and_dgram_socket_exchange)
zassert_not_null(ud.first, "1st Ethernet interface not found");
zassert_not_null(ud.second, "2nd Ethernet interface not found");
sock1 = setup_socket(ud.first, SOCK_DGRAM, ETH_P_ALL);
sock1 = setup_socket(ud.first, SOCK_DGRAM, htons(ETH_P_ALL));
zassert_true(sock1 >= 0, "Cannot create 1st socket (%d)", sock1);
sock2 = setup_socket(ud.second, SOCK_RAW, ETH_P_ALL);
sock2 = setup_socket(ud.second, SOCK_RAW, htons(ETH_P_ALL));
zassert_true(sock2 >= 0, "Cannot create 2nd socket (%d)", sock2);
ret = bind_socket(sock1, ud.first);
@ -520,13 +520,13 @@ ZTEST(socket_packet, test_raw_and_dgram_socket_recv)
zassert_not_null(ud.first, "1st Ethernet interface not found");
zassert_not_null(ud.second, "2nd Ethernet interface not found");
sock1 = setup_socket(ud.first, SOCK_DGRAM, ETH_P_ALL);
sock1 = setup_socket(ud.first, SOCK_DGRAM, htons(ETH_P_ALL));
zassert_true(sock1 >= 0, "Cannot create 1st socket (%d)", sock1);
sock2 = setup_socket(ud.second, SOCK_RAW, ETH_P_ALL);
sock2 = setup_socket(ud.second, SOCK_RAW, htons(ETH_P_ALL));
zassert_true(sock2 >= 0, "Cannot create 2nd socket (%d)", sock2);
sock3 = setup_socket(ud.second, SOCK_RAW, ETH_P_ALL);
sock3 = setup_socket(ud.second, SOCK_RAW, htons(ETH_P_ALL));
zassert_true(sock3 >= 0, "Cannot create 2nd socket (%d)", sock3);
ret = bind_socket(sock1, ud.first);

View file

@ -120,7 +120,7 @@ ZTEST(net_sckt_packet_raw_ip, test_sckt_raw_packet_raw_ip)
char receive_buffer[128];
int sock;
sock = zsock_socket(AF_PACKET, SOCK_RAW, IPPROTO_RAW);
sock = zsock_socket(AF_PACKET, SOCK_RAW, htons(IPPROTO_RAW));
zassert_true(sock >= 0, "Could not create a socket");
dst.sll_ifindex = net_if_get_by_iface(iface);

View file

@ -103,7 +103,7 @@ static const struct test_result {
/* 10 */
.test_case.family = AF_PACKET,
.test_case.type = SOCK_RAW,
.test_case.proto = ETH_P_ALL,
.test_case.proto = htons(ETH_P_ALL),
.result = 0,
},
{
@ -147,14 +147,14 @@ static const struct test_result {
/* 16 */
.test_case.family = AF_PACKET,
.test_case.type = SOCK_RAW,
.test_case.proto = ETH_P_IEEE802154,
.test_case.proto = htons(ETH_P_IEEE802154),
.result = 0,
},
{
/* 17 */
.test_case.family = AF_PACKET,
.test_case.type = SOCK_DGRAM,
.test_case.proto = ETH_P_IEEE802154,
.test_case.proto = htons(ETH_P_IEEE802154),
.result = 0,
},
};
@ -201,6 +201,8 @@ static bool is_tls(int family, int type, int proto)
static bool is_packet(int family, int type, int proto)
{
proto = ntohs(proto);
if (((type == SOCK_RAW) && (proto == ETH_P_ALL || proto == ETH_P_IEEE802154)) ||
((type == SOCK_DGRAM) && (proto > 0))) {
return true;

View file

@ -2155,7 +2155,7 @@ ZTEST(net_socket_udp, test_31_v4_ttl)
prepare_sock_udp_v4(MY_IPV4_ADDR, CLIENT_PORT, &client_sock, &client_addr);
prepare_sock_udp_v4(MY_IPV4_ADDR, SERVER_PORT, &server_sock, &server_addr);
packet_sock = zsock_socket(AF_PACKET, SOCK_RAW, ETH_P_ALL);
packet_sock = zsock_socket(AF_PACKET, SOCK_RAW, htons(ETH_P_ALL));
zassert_true(packet_sock >= 0, "Cannot create packet socket (%d)", -errno);
ret = bind_socket(packet_sock, lo0);
@ -2204,7 +2204,7 @@ ZTEST(net_socket_udp, test_32_v4_mcast_ttl)
prepare_sock_udp_v4(MY_IPV4_ADDR, CLIENT_PORT, &client_sock, &client_addr);
prepare_sock_udp_v4(MY_IPV4_ADDR, SERVER_PORT, &server_sock, &server_addr);
packet_sock = zsock_socket(AF_PACKET, SOCK_RAW, ETH_P_ALL);
packet_sock = zsock_socket(AF_PACKET, SOCK_RAW, htons(ETH_P_ALL));
zassert_true(packet_sock >= 0, "Cannot create packet socket (%d)", -errno);
ret = bind_socket(packet_sock, lo0);
@ -2254,7 +2254,7 @@ ZTEST(net_socket_udp, test_33_v6_mcast_hops)
prepare_sock_udp_v6(MY_IPV6_ADDR, CLIENT_PORT, &client_sock, &client_addr);
prepare_sock_udp_v6(MY_IPV6_ADDR, SERVER_PORT, &server_sock, &server_addr);
packet_sock = zsock_socket(AF_PACKET, SOCK_RAW, ETH_P_ALL);
packet_sock = zsock_socket(AF_PACKET, SOCK_RAW, htons(ETH_P_ALL));
zassert_true(packet_sock >= 0, "Cannot create packet socket (%d)", -errno);
ret = bind_socket(packet_sock, lo0);
@ -2320,7 +2320,7 @@ ZTEST(net_socket_udp, test_34_v6_hops)
prepare_sock_udp_v6(MY_IPV6_ADDR, CLIENT_PORT, &client_sock, &client_addr);
prepare_sock_udp_v6(MY_IPV6_ADDR, SERVER_PORT, &server_sock, &server_addr);
packet_sock = zsock_socket(AF_PACKET, SOCK_RAW, ETH_P_ALL);
packet_sock = zsock_socket(AF_PACKET, SOCK_RAW, htons(ETH_P_ALL));
zassert_true(packet_sock >= 0, "Cannot create packet socket (%d)", -errno);
ret = bind_socket(packet_sock, lo0);