** Also affects: linux Importance: Undecided Status: New ** Changed in: linux (Ubuntu) Status: Incomplete => Confirmed
** No longer affects: linux -- You received this bug notification because you are a member of Kernel Packages, which is subscribed to linux in Ubuntu. https://bugs.launchpad.net/bugs/1826113 Title: socket creation failure - invalid argument error Status in linux package in Ubuntu: Confirmed Bug description: Hi, This code is working in 32 bit ubuntu versions 14.04 and 16.04. Also, this code is working in ubuntu 14.04 64 bit versions. but it is giving socket creation failure error in ubuntu 64 bit. (linux-image-3.19.0-25-generic 32/64 bit both working (ubuntu 14.04), linux-image-4.15.0-45-generic (32 bit working for ubuntu 16.04) and linux-image-4.15.0-47-generic ubunutu 64 bit gives error. Please suggest to this issue to run on 64 bit ubuntu 16.04 and other machines. This code socket fail and returns -1 : s = socket(AF_INET, SOCK_RAW, htons(ETH_P_ALL)); #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <signal.h> #include <sys/socket.h> #include <net/if.h> #include <linux/if_ether.h> #include <linux/if_packet.h> #include <arpa/inet.h> static int s = -1; static int s1 = -1; void onexit(int signum) { (void)signum; printf("Exiting"); close(s); close(s1); } int main() { char buf[1600]; ssize_t recv_size = -1; ssize_t send_size = -1; int i = 0; struct sockaddr_ll socket_address, socket_address1; s = socket(AF_INET, SOCK_RAW, htons(ETH_P_ALL)); s1 = socket(AF_INET, SOCK_RAW, htons(ETH_P_ALL)); if ((s == -1) || (s1 == -1)) { perror("Socket creation failed"); exit (0); } signal(SIGINT, onexit); memset(&socket_address, 0, sizeof (socket_address)); socket_address.sll_family = PF_PACKET; socket_address.sll_ifindex = if_nametoindex("eth0"); socket_address.sll_protocol = htons(ETH_P_ALL); i = bind(s, (struct sockaddr*)&socket_address, sizeof(socket_address)); if (i == -1) { perror("Bind"); exit (0); } memset(&socket_address1, 0, sizeof (socket_address1)); socket_address1.sll_family = PF_PACKET; socket_address1.sll_ifindex = if_nametoindex("eth1"); socket_address1.sll_protocol = htons(ETH_P_ALL); i = bind(s1, (struct sockaddr*)&socket_address1, sizeof(socket_address1)); if (i == -1) { perror("Bind"); exit (0); } while (1) { memset(&buf, 0, sizeof(buf)); recv_size = recv(s, &buf, sizeof(buf), 0); if (recv_size == -1) { perror("Socket receive"); exit (0); } printf("\n"); for(i=0; i < recv_size; i++) { printf("%02x ", buf[i]); } send_size = send(s1, &buf, recv_size, 0); if (send_size == -1) { perror("Socket send"); exit (0); } } return 0; } To manage notifications about this bug go to: https://bugs.launchpad.net/ubuntu/+source/linux/+bug/1826113/+subscriptions -- Mailing list: https://launchpad.net/~kernel-packages Post to : kernel-packages@lists.launchpad.net Unsubscribe : https://launchpad.net/~kernel-packages More help : https://help.launchpad.net/ListHelp