0004-drop-decnet.patch 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. From ec8dcc7faf13c57f5f6d785e4429818f1239a058 Mon Sep 17 00:00:00 2001
  2. From: Fabrice Fontaine <fontaine.fabrice@gmail.com>
  3. Date: Sun, 8 Jan 2023 20:50:18 +0100
  4. Subject: [PATCH] drop decnet
  5. Drop decnet as it has been removed since kernel 6.1 and
  6. https://github.com/torvalds/linux/commit/1202cdd665315c525b5237e96e0bedc76d7e754f
  7. resulting in the following build failure:
  8. net/proto-decnet.c:5:10: fatal error: linux/dn.h: No such file or directory
  9. 5 | #include <linux/dn.h>
  10. | ^~~~~~~~~~~~
  11. Fixes:
  12. - http://autobuild.buildroot.org/results/47e0a5e0b6fcf33ab4f9848d5d8c2be9e5283950
  13. Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
  14. [Upstream status: https://github.com/kernelslacker/trinity/pull/41]
  15. ---
  16. include/net.h | 1 -
  17. net/proto-decnet.c | 59 ----------------------------------------------
  18. net/proto-unix.c | 1 -
  19. net/protocols.c | 1 -
  20. 4 files changed, 62 deletions(-)
  21. delete mode 100644 net/proto-decnet.c
  22. diff --git a/include/net.h b/include/net.h
  23. index 99d55363..791e8090 100644
  24. --- a/include/net.h
  25. +++ b/include/net.h
  26. @@ -80,7 +80,6 @@ extern const struct netproto proto_atmpvc;
  27. extern const struct netproto proto_atmsvc;
  28. extern const struct netproto proto_x25;
  29. extern const struct netproto proto_rose;
  30. -extern const struct netproto proto_decnet;
  31. extern const struct netproto proto_llc;
  32. extern const struct netproto proto_netlink;
  33. extern const struct netproto proto_packet;
  34. diff --git a/net/proto-decnet.c b/net/proto-decnet.c
  35. deleted file mode 100644
  36. index 7711cf00..00000000
  37. --- a/net/proto-decnet.c
  38. +++ /dev/null
  39. @@ -1,59 +0,0 @@
  40. -#include <sys/types.h>
  41. -#include <sys/socket.h>
  42. -#include <sys/un.h>
  43. -#include <netinet/in.h>
  44. -#include <linux/dn.h>
  45. -#include <stdlib.h>
  46. -#include "net.h"
  47. -#include "random.h"
  48. -#include "utils.h" // RAND_ARRAY
  49. -#include "compat.h"
  50. -
  51. -static void decnet_gen_sockaddr(struct sockaddr **addr, socklen_t *addrlen)
  52. -{
  53. - struct sockaddr_dn *dn;
  54. - unsigned int i;
  55. -
  56. - dn = zmalloc(sizeof(struct sockaddr_dn));
  57. -
  58. - dn->sdn_family = PF_DECnet;
  59. - dn->sdn_flags = rnd();
  60. - dn->sdn_objnum = rnd();
  61. - dn->sdn_objnamel = rnd() % 16;
  62. - for (i = 0; i < dn->sdn_objnamel; i++)
  63. - dn->sdn_objname[i] = rnd();
  64. - dn->sdn_add.a_len = RAND_BOOL();
  65. - dn->sdn_add.a_addr[0] = rnd();
  66. - dn->sdn_add.a_addr[1] = rnd();
  67. - *addr = (struct sockaddr *) dn;
  68. - *addrlen = sizeof(struct sockaddr_dn);
  69. -}
  70. -
  71. -static const unsigned int decnet_opts[] = {
  72. - SO_CONDATA, SO_CONACCESS, SO_PROXYUSR, SO_LINKINFO,
  73. - DSO_CONDATA, DSO_DISDATA, DSO_CONACCESS, DSO_ACCEPTMODE,
  74. - DSO_CONACCEPT, DSO_CONREJECT, DSO_LINKINFO, DSO_STREAM,
  75. - DSO_SEQPACKET, DSO_MAXWINDOW, DSO_NODELAY, DSO_CORK,
  76. - DSO_SERVICES, DSO_INFO
  77. -};
  78. -
  79. -static void decnet_setsockopt(struct sockopt *so, __unused__ struct socket_triplet *triplet)
  80. -{
  81. - so->level = SOL_DECNET;
  82. - so->optname = RAND_ARRAY(decnet_opts);
  83. -
  84. - // TODO: set optlen correctly
  85. -}
  86. -
  87. -static struct socket_triplet decnet_triplets[] = {
  88. - { .family = PF_DECnet, .protocol = DNPROTO_NSP, .type = SOCK_SEQPACKET },
  89. - { .family = PF_DECnet, .protocol = DNPROTO_NSP, .type = SOCK_STREAM },
  90. -};
  91. -
  92. -const struct netproto proto_decnet = {
  93. - .name = "decnet",
  94. - .setsockopt = decnet_setsockopt,
  95. - .gen_sockaddr = decnet_gen_sockaddr,
  96. - .valid_triplets = decnet_triplets,
  97. - .nr_triplets = ARRAY_SIZE(decnet_triplets),
  98. -};
  99. diff --git a/net/proto-unix.c b/net/proto-unix.c
  100. index f7427a22..119c1429 100644
  101. --- a/net/proto-unix.c
  102. +++ b/net/proto-unix.c
  103. @@ -2,7 +2,6 @@
  104. #include <sys/socket.h>
  105. #include <sys/un.h>
  106. #include <netinet/in.h>
  107. -#include <linux/dn.h>
  108. #include <stdlib.h>
  109. #include "net.h"
  110. #include "random.h"
  111. diff --git a/net/protocols.c b/net/protocols.c
  112. index ea64d5f5..278f08b5 100644
  113. --- a/net/protocols.c
  114. +++ b/net/protocols.c
  115. @@ -18,7 +18,6 @@ const struct protoptr net_protocols[TRINITY_PF_MAX] = {
  116. #ifdef USE_IPV6
  117. [PF_INET6] = { .proto = &proto_inet6 },
  118. #endif
  119. - [PF_DECnet] = { .proto = &proto_decnet },
  120. [PF_PACKET] = { .proto = &proto_packet },
  121. #ifdef USE_NETECONET
  122. [PF_ECONET] = { .proto = &proto_econet },
  123. --
  124. 2.39.0