af_packet.c 55 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509
  1. /*
  2. * INET An implementation of the TCP/IP protocol suite for the LINUX
  3. * operating system. INET is implemented using the BSD Socket
  4. * interface as the means of communication with the user level.
  5. *
  6. * PACKET - implements raw packet sockets.
  7. *
  8. * Authors: Ross Biro
  9. * Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
  10. * Alan Cox, <gw4pts@gw4pts.ampr.org>
  11. *
  12. * Fixes:
  13. * Alan Cox : verify_area() now used correctly
  14. * Alan Cox : new skbuff lists, look ma no backlogs!
  15. * Alan Cox : tidied skbuff lists.
  16. * Alan Cox : Now uses generic datagram routines I
  17. * added. Also fixed the peek/read crash
  18. * from all old Linux datagram code.
  19. * Alan Cox : Uses the improved datagram code.
  20. * Alan Cox : Added NULL's for socket options.
  21. * Alan Cox : Re-commented the code.
  22. * Alan Cox : Use new kernel side addressing
  23. * Rob Janssen : Correct MTU usage.
  24. * Dave Platt : Counter leaks caused by incorrect
  25. * interrupt locking and some slightly
  26. * dubious gcc output. Can you read
  27. * compiler: it said _VOLATILE_
  28. * Richard Kooijman : Timestamp fixes.
  29. * Alan Cox : New buffers. Use sk->mac.raw.
  30. * Alan Cox : sendmsg/recvmsg support.
  31. * Alan Cox : Protocol setting support
  32. * Alexey Kuznetsov : Untied from IPv4 stack.
  33. * Cyrus Durgin : Fixed kerneld for kmod.
  34. * Michal Ostrowski : Module initialization cleanup.
  35. * Ulises Alonso : Frame number limit removal and
  36. * packet_set_ring memory leak.
  37. * Eric Biederman : Allow for > 8 byte hardware addresses.
  38. * The convention is that longer addresses
  39. * will simply extend the hardware address
  40. * byte arrays at the end of sockaddr_ll
  41. * and packet_mreq.
  42. * Johann Baudy : Added TX RING.
  43. *
  44. * This program is free software; you can redistribute it and/or
  45. * modify it under the terms of the GNU General Public License
  46. * as published by the Free Software Foundation; either version
  47. * 2 of the License, or (at your option) any later version.
  48. *
  49. */
  50. #include <linux/types.h>
  51. #include <linux/mm.h>
  52. #include <linux/capability.h>
  53. #include <linux/fcntl.h>
  54. #include <linux/socket.h>
  55. #include <linux/in.h>
  56. #include <linux/inet.h>
  57. #include <linux/netdevice.h>
  58. #include <linux/if_packet.h>
  59. #include <linux/wireless.h>
  60. #include <linux/kernel.h>
  61. #include <linux/kmod.h>
  62. #include <net/net_namespace.h>
  63. #include <net/ip.h>
  64. #include <net/protocol.h>
  65. #include <linux/skbuff.h>
  66. #include <net/sock.h>
  67. #include <linux/errno.h>
  68. #include <linux/timer.h>
  69. #include <asm/system.h>
  70. #include <asm/uaccess.h>
  71. #include <asm/ioctls.h>
  72. #include <asm/page.h>
  73. #include <asm/cacheflush.h>
  74. #include <asm/io.h>
  75. #include <linux/proc_fs.h>
  76. #include <linux/seq_file.h>
  77. #include <linux/poll.h>
  78. #include <linux/module.h>
  79. #include <linux/init.h>
  80. #include <linux/mutex.h>
  81. #ifdef CONFIG_INET
  82. #include <net/inet_common.h>
  83. #endif
  84. /*
  85. Assumptions:
  86. - if device has no dev->hard_header routine, it adds and removes ll header
  87. inside itself. In this case ll header is invisible outside of device,
  88. but higher levels still should reserve dev->hard_header_len.
  89. Some devices are enough clever to reallocate skb, when header
  90. will not fit to reserved space (tunnel), another ones are silly
  91. (PPP).
  92. - packet socket receives packets with pulled ll header,
  93. so that SOCK_RAW should push it back.
  94. On receive:
  95. -----------
  96. Incoming, dev->hard_header!=NULL
  97. mac_header -> ll header
  98. data -> data
  99. Outgoing, dev->hard_header!=NULL
  100. mac_header -> ll header
  101. data -> ll header
  102. Incoming, dev->hard_header==NULL
  103. mac_header -> UNKNOWN position. It is very likely, that it points to ll
  104. header. PPP makes it, that is wrong, because introduce
  105. assymetry between rx and tx paths.
  106. data -> data
  107. Outgoing, dev->hard_header==NULL
  108. mac_header -> data. ll header is still not built!
  109. data -> data
  110. Resume
  111. If dev->hard_header==NULL we are unlikely to restore sensible ll header.
  112. On transmit:
  113. ------------
  114. dev->hard_header != NULL
  115. mac_header -> ll header
  116. data -> ll header
  117. dev->hard_header == NULL (ll header is added by device, we cannot control it)
  118. mac_header -> data
  119. data -> data
  120. We should set nh.raw on output to correct posistion,
  121. packet classifier depends on it.
  122. */
  123. /* Private packet socket structures. */
  124. struct packet_mclist
  125. {
  126. struct packet_mclist *next;
  127. int ifindex;
  128. int count;
  129. unsigned short type;
  130. unsigned short alen;
  131. unsigned char addr[MAX_ADDR_LEN];
  132. };
  133. /* identical to struct packet_mreq except it has
  134. * a longer address field.
  135. */
  136. struct packet_mreq_max
  137. {
  138. int mr_ifindex;
  139. unsigned short mr_type;
  140. unsigned short mr_alen;
  141. unsigned char mr_address[MAX_ADDR_LEN];
  142. };
  143. #ifdef CONFIG_PACKET_MMAP
  144. static int packet_set_ring(struct sock *sk, struct tpacket_req *req,
  145. int closing, int tx_ring);
  146. struct packet_ring_buffer {
  147. char * *pg_vec;
  148. unsigned int head;
  149. unsigned int frames_per_block;
  150. unsigned int frame_size;
  151. unsigned int frame_max;
  152. unsigned int pg_vec_order;
  153. unsigned int pg_vec_pages;
  154. unsigned int pg_vec_len;
  155. atomic_t pending;
  156. };
  157. struct packet_sock;
  158. static int tpacket_snd(struct packet_sock *po, struct msghdr *msg);
  159. #endif
  160. static void packet_flush_mclist(struct sock *sk);
  161. struct packet_sock {
  162. /* struct sock has to be the first member of packet_sock */
  163. struct sock sk;
  164. struct tpacket_stats stats;
  165. #ifdef CONFIG_PACKET_MMAP
  166. struct packet_ring_buffer rx_ring;
  167. struct packet_ring_buffer tx_ring;
  168. int copy_thresh;
  169. #endif
  170. struct packet_type prot_hook;
  171. spinlock_t bind_lock;
  172. struct mutex pg_vec_lock;
  173. unsigned int running:1, /* prot_hook is attached*/
  174. auxdata:1,
  175. origdev:1;
  176. int ifindex; /* bound device */
  177. __be16 num;
  178. struct packet_mclist *mclist;
  179. #ifdef CONFIG_PACKET_MMAP
  180. atomic_t mapped;
  181. enum tpacket_versions tp_version;
  182. unsigned int tp_hdrlen;
  183. unsigned int tp_reserve;
  184. unsigned int tp_loss:1;
  185. #endif
  186. };
  187. struct packet_skb_cb {
  188. unsigned int origlen;
  189. union {
  190. struct sockaddr_pkt pkt;
  191. struct sockaddr_ll ll;
  192. } sa;
  193. };
  194. #define PACKET_SKB_CB(__skb) ((struct packet_skb_cb *)((__skb)->cb))
  195. #ifdef CONFIG_PACKET_MMAP
  196. static void __packet_set_status(struct packet_sock *po, void *frame, int status)
  197. {
  198. union {
  199. struct tpacket_hdr *h1;
  200. struct tpacket2_hdr *h2;
  201. void *raw;
  202. } h;
  203. h.raw = frame;
  204. switch (po->tp_version) {
  205. case TPACKET_V1:
  206. h.h1->tp_status = status;
  207. flush_dcache_page(virt_to_page(&h.h1->tp_status));
  208. break;
  209. case TPACKET_V2:
  210. h.h2->tp_status = status;
  211. flush_dcache_page(virt_to_page(&h.h2->tp_status));
  212. break;
  213. default:
  214. printk(KERN_ERR "TPACKET version not supported\n");
  215. BUG();
  216. }
  217. smp_wmb();
  218. }
  219. static int __packet_get_status(struct packet_sock *po, void *frame)
  220. {
  221. union {
  222. struct tpacket_hdr *h1;
  223. struct tpacket2_hdr *h2;
  224. void *raw;
  225. } h;
  226. smp_rmb();
  227. h.raw = frame;
  228. switch (po->tp_version) {
  229. case TPACKET_V1:
  230. flush_dcache_page(virt_to_page(&h.h1->tp_status));
  231. return h.h1->tp_status;
  232. case TPACKET_V2:
  233. flush_dcache_page(virt_to_page(&h.h2->tp_status));
  234. return h.h2->tp_status;
  235. default:
  236. printk(KERN_ERR "TPACKET version not supported\n");
  237. BUG();
  238. return 0;
  239. }
  240. }
  241. static void *packet_lookup_frame(struct packet_sock *po,
  242. struct packet_ring_buffer *rb,
  243. unsigned int position,
  244. int status)
  245. {
  246. unsigned int pg_vec_pos, frame_offset;
  247. union {
  248. struct tpacket_hdr *h1;
  249. struct tpacket2_hdr *h2;
  250. void *raw;
  251. } h;
  252. pg_vec_pos = position / rb->frames_per_block;
  253. frame_offset = position % rb->frames_per_block;
  254. h.raw = rb->pg_vec[pg_vec_pos] + (frame_offset * rb->frame_size);
  255. if (status != __packet_get_status(po, h.raw))
  256. return NULL;
  257. return h.raw;
  258. }
  259. static inline void *packet_current_frame(struct packet_sock *po,
  260. struct packet_ring_buffer *rb,
  261. int status)
  262. {
  263. return packet_lookup_frame(po, rb, rb->head, status);
  264. }
  265. static inline void *packet_previous_frame(struct packet_sock *po,
  266. struct packet_ring_buffer *rb,
  267. int status)
  268. {
  269. unsigned int previous = rb->head ? rb->head - 1 : rb->frame_max;
  270. return packet_lookup_frame(po, rb, previous, status);
  271. }
  272. static inline void packet_increment_head(struct packet_ring_buffer *buff)
  273. {
  274. buff->head = buff->head != buff->frame_max ? buff->head+1 : 0;
  275. }
  276. #endif
  277. static inline struct packet_sock *pkt_sk(struct sock *sk)
  278. {
  279. return (struct packet_sock *)sk;
  280. }
  281. static void packet_sock_destruct(struct sock *sk)
  282. {
  283. WARN_ON(atomic_read(&sk->sk_rmem_alloc));
  284. WARN_ON(atomic_read(&sk->sk_wmem_alloc));
  285. if (!sock_flag(sk, SOCK_DEAD)) {
  286. printk("Attempt to release alive packet socket: %p\n", sk);
  287. return;
  288. }
  289. sk_refcnt_debug_dec(sk);
  290. }
  291. static const struct proto_ops packet_ops;
  292. static const struct proto_ops packet_ops_spkt;
  293. static int packet_rcv_spkt(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt, struct net_device *orig_dev)
  294. {
  295. struct sock *sk;
  296. struct sockaddr_pkt *spkt;
  297. /*
  298. * When we registered the protocol we saved the socket in the data
  299. * field for just this event.
  300. */
  301. sk = pt->af_packet_priv;
  302. /*
  303. * Yank back the headers [hope the device set this
  304. * right or kerboom...]
  305. *
  306. * Incoming packets have ll header pulled,
  307. * push it back.
  308. *
  309. * For outgoing ones skb->data == skb_mac_header(skb)
  310. * so that this procedure is noop.
  311. */
  312. if (skb->pkt_type == PACKET_LOOPBACK)
  313. goto out;
  314. if (dev_net(dev) != sock_net(sk))
  315. goto out;
  316. if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL)
  317. goto oom;
  318. /* drop any routing info */
  319. skb_dst_drop(skb);
  320. /* drop conntrack reference */
  321. nf_reset(skb);
  322. spkt = &PACKET_SKB_CB(skb)->sa.pkt;
  323. skb_push(skb, skb->data - skb_mac_header(skb));
  324. /*
  325. * The SOCK_PACKET socket receives _all_ frames.
  326. */
  327. spkt->spkt_family = dev->type;
  328. strlcpy(spkt->spkt_device, dev->name, sizeof(spkt->spkt_device));
  329. spkt->spkt_protocol = skb->protocol;
  330. /*
  331. * Charge the memory to the socket. This is done specifically
  332. * to prevent sockets using all the memory up.
  333. */
  334. if (sock_queue_rcv_skb(sk,skb) == 0)
  335. return 0;
  336. out:
  337. kfree_skb(skb);
  338. oom:
  339. return 0;
  340. }
  341. /*
  342. * Output a raw packet to a device layer. This bypasses all the other
  343. * protocol layers and you must therefore supply it with a complete frame
  344. */
  345. static int packet_sendmsg_spkt(struct kiocb *iocb, struct socket *sock,
  346. struct msghdr *msg, size_t len)
  347. {
  348. struct sock *sk = sock->sk;
  349. struct sockaddr_pkt *saddr=(struct sockaddr_pkt *)msg->msg_name;
  350. struct sk_buff *skb;
  351. struct net_device *dev;
  352. __be16 proto=0;
  353. int err;
  354. /*
  355. * Get and verify the address.
  356. */
  357. if (saddr)
  358. {
  359. if (msg->msg_namelen < sizeof(struct sockaddr))
  360. return(-EINVAL);
  361. if (msg->msg_namelen==sizeof(struct sockaddr_pkt))
  362. proto=saddr->spkt_protocol;
  363. }
  364. else
  365. return(-ENOTCONN); /* SOCK_PACKET must be sent giving an address */
  366. /*
  367. * Find the device first to size check it
  368. */
  369. saddr->spkt_device[13] = 0;
  370. dev = dev_get_by_name(sock_net(sk), saddr->spkt_device);
  371. err = -ENODEV;
  372. if (dev == NULL)
  373. goto out_unlock;
  374. err = -ENETDOWN;
  375. if (!(dev->flags & IFF_UP))
  376. goto out_unlock;
  377. /*
  378. * You may not queue a frame bigger than the mtu. This is the lowest level
  379. * raw protocol and you must do your own fragmentation at this level.
  380. */
  381. err = -EMSGSIZE;
  382. if (len > dev->mtu + dev->hard_header_len)
  383. goto out_unlock;
  384. err = -ENOBUFS;
  385. skb = sock_wmalloc(sk, len + LL_RESERVED_SPACE(dev), 0, GFP_KERNEL);
  386. /*
  387. * If the write buffer is full, then tough. At this level the user gets to
  388. * deal with the problem - do your own algorithmic backoffs. That's far
  389. * more flexible.
  390. */
  391. if (skb == NULL)
  392. goto out_unlock;
  393. /*
  394. * Fill it in
  395. */
  396. /* FIXME: Save some space for broken drivers that write a
  397. * hard header at transmission time by themselves. PPP is the
  398. * notable one here. This should really be fixed at the driver level.
  399. */
  400. skb_reserve(skb, LL_RESERVED_SPACE(dev));
  401. skb_reset_network_header(skb);
  402. /* Try to align data part correctly */
  403. if (dev->header_ops) {
  404. skb->data -= dev->hard_header_len;
  405. skb->tail -= dev->hard_header_len;
  406. if (len < dev->hard_header_len)
  407. skb_reset_network_header(skb);
  408. }
  409. /* Returns -EFAULT on error */
  410. err = memcpy_fromiovec(skb_put(skb,len), msg->msg_iov, len);
  411. skb->protocol = proto;
  412. skb->dev = dev;
  413. skb->priority = sk->sk_priority;
  414. if (err)
  415. goto out_free;
  416. /*
  417. * Now send it
  418. */
  419. dev_queue_xmit(skb);
  420. dev_put(dev);
  421. return(len);
  422. out_free:
  423. kfree_skb(skb);
  424. out_unlock:
  425. if (dev)
  426. dev_put(dev);
  427. return err;
  428. }
  429. static inline unsigned int run_filter(struct sk_buff *skb, struct sock *sk,
  430. unsigned int res)
  431. {
  432. struct sk_filter *filter;
  433. rcu_read_lock_bh();
  434. filter = rcu_dereference(sk->sk_filter);
  435. if (filter != NULL)
  436. res = sk_run_filter(skb, filter->insns, filter->len);
  437. rcu_read_unlock_bh();
  438. return res;
  439. }
  440. /*
  441. This function makes lazy skb cloning in hope that most of packets
  442. are discarded by BPF.
  443. Note tricky part: we DO mangle shared skb! skb->data, skb->len
  444. and skb->cb are mangled. It works because (and until) packets
  445. falling here are owned by current CPU. Output packets are cloned
  446. by dev_queue_xmit_nit(), input packets are processed by net_bh
  447. sequencially, so that if we return skb to original state on exit,
  448. we will not harm anyone.
  449. */
  450. static int packet_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt, struct net_device *orig_dev)
  451. {
  452. struct sock *sk;
  453. struct sockaddr_ll *sll;
  454. struct packet_sock *po;
  455. u8 * skb_head = skb->data;
  456. int skb_len = skb->len;
  457. unsigned int snaplen, res;
  458. if (skb->pkt_type == PACKET_LOOPBACK)
  459. goto drop;
  460. sk = pt->af_packet_priv;
  461. po = pkt_sk(sk);
  462. if (dev_net(dev) != sock_net(sk))
  463. goto drop;
  464. skb->dev = dev;
  465. if (dev->header_ops) {
  466. /* The device has an explicit notion of ll header,
  467. exported to higher levels.
  468. Otherwise, the device hides datails of it frame
  469. structure, so that corresponding packet head
  470. never delivered to user.
  471. */
  472. if (sk->sk_type != SOCK_DGRAM)
  473. skb_push(skb, skb->data - skb_mac_header(skb));
  474. else if (skb->pkt_type == PACKET_OUTGOING) {
  475. /* Special case: outgoing packets have ll header at head */
  476. skb_pull(skb, skb_network_offset(skb));
  477. }
  478. }
  479. snaplen = skb->len;
  480. res = run_filter(skb, sk, snaplen);
  481. if (!res)
  482. goto drop_n_restore;
  483. if (snaplen > res)
  484. snaplen = res;
  485. if (atomic_read(&sk->sk_rmem_alloc) + skb->truesize >=
  486. (unsigned)sk->sk_rcvbuf)
  487. goto drop_n_acct;
  488. if (skb_shared(skb)) {
  489. struct sk_buff *nskb = skb_clone(skb, GFP_ATOMIC);
  490. if (nskb == NULL)
  491. goto drop_n_acct;
  492. if (skb_head != skb->data) {
  493. skb->data = skb_head;
  494. skb->len = skb_len;
  495. }
  496. kfree_skb(skb);
  497. skb = nskb;
  498. }
  499. BUILD_BUG_ON(sizeof(*PACKET_SKB_CB(skb)) + MAX_ADDR_LEN - 8 >
  500. sizeof(skb->cb));
  501. sll = &PACKET_SKB_CB(skb)->sa.ll;
  502. sll->sll_family = AF_PACKET;
  503. sll->sll_hatype = dev->type;
  504. sll->sll_protocol = skb->protocol;
  505. sll->sll_pkttype = skb->pkt_type;
  506. if (unlikely(po->origdev))
  507. sll->sll_ifindex = orig_dev->ifindex;
  508. else
  509. sll->sll_ifindex = dev->ifindex;
  510. sll->sll_halen = dev_parse_header(skb, sll->sll_addr);
  511. PACKET_SKB_CB(skb)->origlen = skb->len;
  512. if (pskb_trim(skb, snaplen))
  513. goto drop_n_acct;
  514. skb_set_owner_r(skb, sk);
  515. skb->dev = NULL;
  516. skb_dst_drop(skb);
  517. /* drop conntrack reference */
  518. nf_reset(skb);
  519. spin_lock(&sk->sk_receive_queue.lock);
  520. po->stats.tp_packets++;
  521. __skb_queue_tail(&sk->sk_receive_queue, skb);
  522. spin_unlock(&sk->sk_receive_queue.lock);
  523. sk->sk_data_ready(sk, skb->len);
  524. return 0;
  525. drop_n_acct:
  526. spin_lock(&sk->sk_receive_queue.lock);
  527. po->stats.tp_drops++;
  528. spin_unlock(&sk->sk_receive_queue.lock);
  529. drop_n_restore:
  530. if (skb_head != skb->data && skb_shared(skb)) {
  531. skb->data = skb_head;
  532. skb->len = skb_len;
  533. }
  534. drop:
  535. consume_skb(skb);
  536. return 0;
  537. }
  538. #ifdef CONFIG_PACKET_MMAP
  539. static int tpacket_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt, struct net_device *orig_dev)
  540. {
  541. struct sock *sk;
  542. struct packet_sock *po;
  543. struct sockaddr_ll *sll;
  544. union {
  545. struct tpacket_hdr *h1;
  546. struct tpacket2_hdr *h2;
  547. void *raw;
  548. } h;
  549. u8 * skb_head = skb->data;
  550. int skb_len = skb->len;
  551. unsigned int snaplen, res;
  552. unsigned long status = TP_STATUS_LOSING|TP_STATUS_USER;
  553. unsigned short macoff, netoff, hdrlen;
  554. struct sk_buff *copy_skb = NULL;
  555. struct timeval tv;
  556. struct timespec ts;
  557. if (skb->pkt_type == PACKET_LOOPBACK)
  558. goto drop;
  559. sk = pt->af_packet_priv;
  560. po = pkt_sk(sk);
  561. if (dev_net(dev) != sock_net(sk))
  562. goto drop;
  563. if (dev->header_ops) {
  564. if (sk->sk_type != SOCK_DGRAM)
  565. skb_push(skb, skb->data - skb_mac_header(skb));
  566. else if (skb->pkt_type == PACKET_OUTGOING) {
  567. /* Special case: outgoing packets have ll header at head */
  568. skb_pull(skb, skb_network_offset(skb));
  569. }
  570. }
  571. if (skb->ip_summed == CHECKSUM_PARTIAL)
  572. status |= TP_STATUS_CSUMNOTREADY;
  573. snaplen = skb->len;
  574. res = run_filter(skb, sk, snaplen);
  575. if (!res)
  576. goto drop_n_restore;
  577. if (snaplen > res)
  578. snaplen = res;
  579. if (sk->sk_type == SOCK_DGRAM) {
  580. macoff = netoff = TPACKET_ALIGN(po->tp_hdrlen) + 16 +
  581. po->tp_reserve;
  582. } else {
  583. unsigned maclen = skb_network_offset(skb);
  584. netoff = TPACKET_ALIGN(po->tp_hdrlen +
  585. (maclen < 16 ? 16 : maclen)) +
  586. po->tp_reserve;
  587. macoff = netoff - maclen;
  588. }
  589. if (macoff + snaplen > po->rx_ring.frame_size) {
  590. if (po->copy_thresh &&
  591. atomic_read(&sk->sk_rmem_alloc) + skb->truesize <
  592. (unsigned)sk->sk_rcvbuf) {
  593. if (skb_shared(skb)) {
  594. copy_skb = skb_clone(skb, GFP_ATOMIC);
  595. } else {
  596. copy_skb = skb_get(skb);
  597. skb_head = skb->data;
  598. }
  599. if (copy_skb)
  600. skb_set_owner_r(copy_skb, sk);
  601. }
  602. snaplen = po->rx_ring.frame_size - macoff;
  603. if ((int)snaplen < 0)
  604. snaplen = 0;
  605. }
  606. spin_lock(&sk->sk_receive_queue.lock);
  607. h.raw = packet_current_frame(po, &po->rx_ring, TP_STATUS_KERNEL);
  608. if (!h.raw)
  609. goto ring_is_full;
  610. packet_increment_head(&po->rx_ring);
  611. po->stats.tp_packets++;
  612. if (copy_skb) {
  613. status |= TP_STATUS_COPY;
  614. __skb_queue_tail(&sk->sk_receive_queue, copy_skb);
  615. }
  616. if (!po->stats.tp_drops)
  617. status &= ~TP_STATUS_LOSING;
  618. spin_unlock(&sk->sk_receive_queue.lock);
  619. skb_copy_bits(skb, 0, h.raw + macoff, snaplen);
  620. switch (po->tp_version) {
  621. case TPACKET_V1:
  622. h.h1->tp_len = skb->len;
  623. h.h1->tp_snaplen = snaplen;
  624. h.h1->tp_mac = macoff;
  625. h.h1->tp_net = netoff;
  626. if (skb->tstamp.tv64)
  627. tv = ktime_to_timeval(skb->tstamp);
  628. else
  629. do_gettimeofday(&tv);
  630. h.h1->tp_sec = tv.tv_sec;
  631. h.h1->tp_usec = tv.tv_usec;
  632. hdrlen = sizeof(*h.h1);
  633. break;
  634. case TPACKET_V2:
  635. h.h2->tp_len = skb->len;
  636. h.h2->tp_snaplen = snaplen;
  637. h.h2->tp_mac = macoff;
  638. h.h2->tp_net = netoff;
  639. if (skb->tstamp.tv64)
  640. ts = ktime_to_timespec(skb->tstamp);
  641. else
  642. getnstimeofday(&ts);
  643. h.h2->tp_sec = ts.tv_sec;
  644. h.h2->tp_nsec = ts.tv_nsec;
  645. h.h2->tp_vlan_tci = skb->vlan_tci;
  646. hdrlen = sizeof(*h.h2);
  647. break;
  648. default:
  649. BUG();
  650. }
  651. sll = h.raw + TPACKET_ALIGN(hdrlen);
  652. sll->sll_halen = dev_parse_header(skb, sll->sll_addr);
  653. sll->sll_family = AF_PACKET;
  654. sll->sll_hatype = dev->type;
  655. sll->sll_protocol = skb->protocol;
  656. sll->sll_pkttype = skb->pkt_type;
  657. if (unlikely(po->origdev))
  658. sll->sll_ifindex = orig_dev->ifindex;
  659. else
  660. sll->sll_ifindex = dev->ifindex;
  661. __packet_set_status(po, h.raw, status);
  662. smp_mb();
  663. {
  664. struct page *p_start, *p_end;
  665. u8 *h_end = h.raw + macoff + snaplen - 1;
  666. p_start = virt_to_page(h.raw);
  667. p_end = virt_to_page(h_end);
  668. while (p_start <= p_end) {
  669. flush_dcache_page(p_start);
  670. p_start++;
  671. }
  672. }
  673. sk->sk_data_ready(sk, 0);
  674. drop_n_restore:
  675. if (skb_head != skb->data && skb_shared(skb)) {
  676. skb->data = skb_head;
  677. skb->len = skb_len;
  678. }
  679. drop:
  680. kfree_skb(skb);
  681. return 0;
  682. ring_is_full:
  683. po->stats.tp_drops++;
  684. spin_unlock(&sk->sk_receive_queue.lock);
  685. sk->sk_data_ready(sk, 0);
  686. kfree_skb(copy_skb);
  687. goto drop_n_restore;
  688. }
  689. static void tpacket_destruct_skb(struct sk_buff *skb)
  690. {
  691. struct packet_sock *po = pkt_sk(skb->sk);
  692. void * ph;
  693. BUG_ON(skb == NULL);
  694. if (likely(po->tx_ring.pg_vec)) {
  695. ph = skb_shinfo(skb)->destructor_arg;
  696. BUG_ON(__packet_get_status(po, ph) != TP_STATUS_SENDING);
  697. BUG_ON(atomic_read(&po->tx_ring.pending) == 0);
  698. atomic_dec(&po->tx_ring.pending);
  699. __packet_set_status(po, ph, TP_STATUS_AVAILABLE);
  700. }
  701. sock_wfree(skb);
  702. }
  703. static int tpacket_fill_skb(struct packet_sock *po, struct sk_buff * skb,
  704. void * frame, struct net_device *dev, int size_max,
  705. __be16 proto, unsigned char * addr)
  706. {
  707. union {
  708. struct tpacket_hdr *h1;
  709. struct tpacket2_hdr *h2;
  710. void *raw;
  711. } ph;
  712. int to_write, offset, len, tp_len, nr_frags, len_max;
  713. struct socket *sock = po->sk.sk_socket;
  714. struct page *page;
  715. void *data;
  716. int err;
  717. ph.raw = frame;
  718. skb->protocol = proto;
  719. skb->dev = dev;
  720. skb->priority = po->sk.sk_priority;
  721. skb_shinfo(skb)->destructor_arg = ph.raw;
  722. switch (po->tp_version) {
  723. case TPACKET_V2:
  724. tp_len = ph.h2->tp_len;
  725. break;
  726. default:
  727. tp_len = ph.h1->tp_len;
  728. break;
  729. }
  730. if (unlikely(tp_len > size_max)) {
  731. printk(KERN_ERR "packet size is too long (%d > %d)\n",
  732. tp_len, size_max);
  733. return -EMSGSIZE;
  734. }
  735. skb_reserve(skb, LL_RESERVED_SPACE(dev));
  736. skb_reset_network_header(skb);
  737. data = ph.raw + po->tp_hdrlen - sizeof(struct sockaddr_ll);
  738. to_write = tp_len;
  739. if (sock->type == SOCK_DGRAM) {
  740. err = dev_hard_header(skb, dev, ntohs(proto), addr,
  741. NULL, tp_len);
  742. if (unlikely(err < 0))
  743. return -EINVAL;
  744. } else if (dev->hard_header_len ) {
  745. /* net device doesn't like empty head */
  746. if (unlikely(tp_len <= dev->hard_header_len)) {
  747. printk(KERN_ERR "packet size is too short "
  748. "(%d < %d)\n", tp_len,
  749. dev->hard_header_len);
  750. return -EINVAL;
  751. }
  752. skb_push(skb, dev->hard_header_len);
  753. err = skb_store_bits(skb, 0, data,
  754. dev->hard_header_len);
  755. if (unlikely(err))
  756. return err;
  757. data += dev->hard_header_len;
  758. to_write -= dev->hard_header_len;
  759. }
  760. err = -EFAULT;
  761. page = virt_to_page(data);
  762. offset = offset_in_page(data);
  763. len_max = PAGE_SIZE - offset;
  764. len = ((to_write > len_max) ? len_max : to_write);
  765. skb->data_len = to_write;
  766. skb->len += to_write;
  767. skb->truesize += to_write;
  768. atomic_add(to_write, &po->sk.sk_wmem_alloc);
  769. while (likely(to_write)) {
  770. nr_frags = skb_shinfo(skb)->nr_frags;
  771. if (unlikely(nr_frags >= MAX_SKB_FRAGS)) {
  772. printk(KERN_ERR "Packet exceed the number "
  773. "of skb frags(%lu)\n",
  774. MAX_SKB_FRAGS);
  775. return -EFAULT;
  776. }
  777. flush_dcache_page(page);
  778. get_page(page);
  779. skb_fill_page_desc(skb,
  780. nr_frags,
  781. page++, offset, len);
  782. to_write -= len;
  783. offset = 0;
  784. len_max = PAGE_SIZE;
  785. len = ((to_write > len_max) ? len_max : to_write);
  786. }
  787. return tp_len;
  788. }
  789. static int tpacket_snd(struct packet_sock *po, struct msghdr *msg)
  790. {
  791. struct socket *sock;
  792. struct sk_buff *skb;
  793. struct net_device *dev;
  794. __be16 proto;
  795. int ifindex, err, reserve = 0;
  796. void * ph;
  797. struct sockaddr_ll *saddr=(struct sockaddr_ll *)msg->msg_name;
  798. int tp_len, size_max;
  799. unsigned char *addr;
  800. int len_sum = 0;
  801. int status = 0;
  802. sock = po->sk.sk_socket;
  803. mutex_lock(&po->pg_vec_lock);
  804. err = -EBUSY;
  805. if (saddr == NULL) {
  806. ifindex = po->ifindex;
  807. proto = po->num;
  808. addr = NULL;
  809. } else {
  810. err = -EINVAL;
  811. if (msg->msg_namelen < sizeof(struct sockaddr_ll))
  812. goto out;
  813. if (msg->msg_namelen < (saddr->sll_halen
  814. + offsetof(struct sockaddr_ll,
  815. sll_addr)))
  816. goto out;
  817. ifindex = saddr->sll_ifindex;
  818. proto = saddr->sll_protocol;
  819. addr = saddr->sll_addr;
  820. }
  821. dev = dev_get_by_index(sock_net(&po->sk), ifindex);
  822. err = -ENXIO;
  823. if (unlikely(dev == NULL))
  824. goto out;
  825. reserve = dev->hard_header_len;
  826. err = -ENETDOWN;
  827. if (unlikely(!(dev->flags & IFF_UP)))
  828. goto out_put;
  829. size_max = po->tx_ring.frame_size
  830. - sizeof(struct skb_shared_info)
  831. - po->tp_hdrlen
  832. - LL_ALLOCATED_SPACE(dev)
  833. - sizeof(struct sockaddr_ll);
  834. if (size_max > dev->mtu + reserve)
  835. size_max = dev->mtu + reserve;
  836. do {
  837. ph = packet_current_frame(po, &po->tx_ring,
  838. TP_STATUS_SEND_REQUEST);
  839. if (unlikely(ph == NULL)) {
  840. schedule();
  841. continue;
  842. }
  843. status = TP_STATUS_SEND_REQUEST;
  844. skb = sock_alloc_send_skb(&po->sk,
  845. LL_ALLOCATED_SPACE(dev)
  846. + sizeof(struct sockaddr_ll),
  847. 0, &err);
  848. if (unlikely(skb == NULL))
  849. goto out_status;
  850. tp_len = tpacket_fill_skb(po, skb, ph, dev, size_max, proto,
  851. addr);
  852. if (unlikely(tp_len < 0)) {
  853. if (po->tp_loss) {
  854. __packet_set_status(po, ph,
  855. TP_STATUS_AVAILABLE);
  856. packet_increment_head(&po->tx_ring);
  857. kfree_skb(skb);
  858. continue;
  859. } else {
  860. status = TP_STATUS_WRONG_FORMAT;
  861. err = tp_len;
  862. goto out_status;
  863. }
  864. }
  865. skb->destructor = tpacket_destruct_skb;
  866. __packet_set_status(po, ph, TP_STATUS_SENDING);
  867. atomic_inc(&po->tx_ring.pending);
  868. status = TP_STATUS_SEND_REQUEST;
  869. err = dev_queue_xmit(skb);
  870. if (unlikely(err > 0 && (err = net_xmit_errno(err)) != 0))
  871. goto out_xmit;
  872. packet_increment_head(&po->tx_ring);
  873. len_sum += tp_len;
  874. }
  875. while (likely((ph != NULL) || ((!(msg->msg_flags & MSG_DONTWAIT))
  876. && (atomic_read(&po->tx_ring.pending))))
  877. );
  878. err = len_sum;
  879. goto out_put;
  880. out_xmit:
  881. skb->destructor = sock_wfree;
  882. atomic_dec(&po->tx_ring.pending);
  883. out_status:
  884. __packet_set_status(po, ph, status);
  885. kfree_skb(skb);
  886. out_put:
  887. dev_put(dev);
  888. out:
  889. mutex_unlock(&po->pg_vec_lock);
  890. return err;
  891. }
  892. #endif
  893. static int packet_snd(struct socket *sock,
  894. struct msghdr *msg, size_t len)
  895. {
  896. struct sock *sk = sock->sk;
  897. struct sockaddr_ll *saddr=(struct sockaddr_ll *)msg->msg_name;
  898. struct sk_buff *skb;
  899. struct net_device *dev;
  900. __be16 proto;
  901. unsigned char *addr;
  902. int ifindex, err, reserve = 0;
  903. /*
  904. * Get and verify the address.
  905. */
  906. if (saddr == NULL) {
  907. struct packet_sock *po = pkt_sk(sk);
  908. ifindex = po->ifindex;
  909. proto = po->num;
  910. addr = NULL;
  911. } else {
  912. err = -EINVAL;
  913. if (msg->msg_namelen < sizeof(struct sockaddr_ll))
  914. goto out;
  915. if (msg->msg_namelen < (saddr->sll_halen + offsetof(struct sockaddr_ll, sll_addr)))
  916. goto out;
  917. ifindex = saddr->sll_ifindex;
  918. proto = saddr->sll_protocol;
  919. addr = saddr->sll_addr;
  920. }
  921. dev = dev_get_by_index(sock_net(sk), ifindex);
  922. err = -ENXIO;
  923. if (dev == NULL)
  924. goto out_unlock;
  925. if (sock->type == SOCK_RAW)
  926. reserve = dev->hard_header_len;
  927. err = -ENETDOWN;
  928. if (!(dev->flags & IFF_UP))
  929. goto out_unlock;
  930. err = -EMSGSIZE;
  931. if (len > dev->mtu+reserve)
  932. goto out_unlock;
  933. skb = sock_alloc_send_skb(sk, len + LL_ALLOCATED_SPACE(dev),
  934. msg->msg_flags & MSG_DONTWAIT, &err);
  935. if (skb==NULL)
  936. goto out_unlock;
  937. skb_reserve(skb, LL_RESERVED_SPACE(dev));
  938. skb_reset_network_header(skb);
  939. err = -EINVAL;
  940. if (sock->type == SOCK_DGRAM &&
  941. dev_hard_header(skb, dev, ntohs(proto), addr, NULL, len) < 0)
  942. goto out_free;
  943. /* Returns -EFAULT on error */
  944. err = memcpy_fromiovec(skb_put(skb,len), msg->msg_iov, len);
  945. if (err)
  946. goto out_free;
  947. skb->protocol = proto;
  948. skb->dev = dev;
  949. skb->priority = sk->sk_priority;
  950. /*
  951. * Now send it
  952. */
  953. err = dev_queue_xmit(skb);
  954. if (err > 0 && (err = net_xmit_errno(err)) != 0)
  955. goto out_unlock;
  956. dev_put(dev);
  957. return(len);
  958. out_free:
  959. kfree_skb(skb);
  960. out_unlock:
  961. if (dev)
  962. dev_put(dev);
  963. out:
  964. return err;
  965. }
  966. static int packet_sendmsg(struct kiocb *iocb, struct socket *sock,
  967. struct msghdr *msg, size_t len)
  968. {
  969. #ifdef CONFIG_PACKET_MMAP
  970. struct sock *sk = sock->sk;
  971. struct packet_sock *po = pkt_sk(sk);
  972. if (po->tx_ring.pg_vec)
  973. return tpacket_snd(po, msg);
  974. else
  975. #endif
  976. return packet_snd(sock, msg, len);
  977. }
  978. /*
  979. * Close a PACKET socket. This is fairly simple. We immediately go
  980. * to 'closed' state and remove our protocol entry in the device list.
  981. */
  982. static int packet_release(struct socket *sock)
  983. {
  984. struct sock *sk = sock->sk;
  985. struct packet_sock *po;
  986. struct net *net;
  987. #ifdef CONFIG_PACKET_MMAP
  988. struct tpacket_req req;
  989. #endif
  990. if (!sk)
  991. return 0;
  992. net = sock_net(sk);
  993. po = pkt_sk(sk);
  994. write_lock_bh(&net->packet.sklist_lock);
  995. sk_del_node_init(sk);
  996. sock_prot_inuse_add(net, sk->sk_prot, -1);
  997. write_unlock_bh(&net->packet.sklist_lock);
  998. /*
  999. * Unhook packet receive handler.
  1000. */
  1001. if (po->running) {
  1002. /*
  1003. * Remove the protocol hook
  1004. */
  1005. dev_remove_pack(&po->prot_hook);
  1006. po->running = 0;
  1007. po->num = 0;
  1008. __sock_put(sk);
  1009. }
  1010. packet_flush_mclist(sk);
  1011. #ifdef CONFIG_PACKET_MMAP
  1012. memset(&req, 0, sizeof(req));
  1013. if (po->rx_ring.pg_vec)
  1014. packet_set_ring(sk, &req, 1, 0);
  1015. if (po->tx_ring.pg_vec)
  1016. packet_set_ring(sk, &req, 1, 1);
  1017. #endif
  1018. /*
  1019. * Now the socket is dead. No more input will appear.
  1020. */
  1021. sock_orphan(sk);
  1022. sock->sk = NULL;
  1023. /* Purge queues */
  1024. skb_queue_purge(&sk->sk_receive_queue);
  1025. sk_refcnt_debug_release(sk);
  1026. sock_put(sk);
  1027. return 0;
  1028. }
  1029. /*
  1030. * Attach a packet hook.
  1031. */
  1032. static int packet_do_bind(struct sock *sk, struct net_device *dev, __be16 protocol)
  1033. {
  1034. struct packet_sock *po = pkt_sk(sk);
  1035. /*
  1036. * Detach an existing hook if present.
  1037. */
  1038. lock_sock(sk);
  1039. spin_lock(&po->bind_lock);
  1040. if (po->running) {
  1041. __sock_put(sk);
  1042. po->running = 0;
  1043. po->num = 0;
  1044. spin_unlock(&po->bind_lock);
  1045. dev_remove_pack(&po->prot_hook);
  1046. spin_lock(&po->bind_lock);
  1047. }
  1048. po->num = protocol;
  1049. po->prot_hook.type = protocol;
  1050. po->prot_hook.dev = dev;
  1051. po->ifindex = dev ? dev->ifindex : 0;
  1052. if (protocol == 0)
  1053. goto out_unlock;
  1054. if (!dev || (dev->flags & IFF_UP)) {
  1055. dev_add_pack(&po->prot_hook);
  1056. sock_hold(sk);
  1057. po->running = 1;
  1058. } else {
  1059. sk->sk_err = ENETDOWN;
  1060. if (!sock_flag(sk, SOCK_DEAD))
  1061. sk->sk_error_report(sk);
  1062. }
  1063. out_unlock:
  1064. spin_unlock(&po->bind_lock);
  1065. release_sock(sk);
  1066. return 0;
  1067. }
  1068. /*
  1069. * Bind a packet socket to a device
  1070. */
  1071. static int packet_bind_spkt(struct socket *sock, struct sockaddr *uaddr, int addr_len)
  1072. {
  1073. struct sock *sk=sock->sk;
  1074. char name[15];
  1075. struct net_device *dev;
  1076. int err = -ENODEV;
  1077. /*
  1078. * Check legality
  1079. */
  1080. if (addr_len != sizeof(struct sockaddr))
  1081. return -EINVAL;
  1082. strlcpy(name,uaddr->sa_data,sizeof(name));
  1083. dev = dev_get_by_name(sock_net(sk), name);
  1084. if (dev) {
  1085. err = packet_do_bind(sk, dev, pkt_sk(sk)->num);
  1086. dev_put(dev);
  1087. }
  1088. return err;
  1089. }
  1090. static int packet_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len)
  1091. {
  1092. struct sockaddr_ll *sll = (struct sockaddr_ll*)uaddr;
  1093. struct sock *sk=sock->sk;
  1094. struct net_device *dev = NULL;
  1095. int err;
  1096. /*
  1097. * Check legality
  1098. */
  1099. if (addr_len < sizeof(struct sockaddr_ll))
  1100. return -EINVAL;
  1101. if (sll->sll_family != AF_PACKET)
  1102. return -EINVAL;
  1103. if (sll->sll_ifindex) {
  1104. err = -ENODEV;
  1105. dev = dev_get_by_index(sock_net(sk), sll->sll_ifindex);
  1106. if (dev == NULL)
  1107. goto out;
  1108. }
  1109. err = packet_do_bind(sk, dev, sll->sll_protocol ? : pkt_sk(sk)->num);
  1110. if (dev)
  1111. dev_put(dev);
  1112. out:
  1113. return err;
  1114. }
  1115. static struct proto packet_proto = {
  1116. .name = "PACKET",
  1117. .owner = THIS_MODULE,
  1118. .obj_size = sizeof(struct packet_sock),
  1119. };
  1120. /*
  1121. * Create a packet of type SOCK_PACKET.
  1122. */
  1123. static int packet_create(struct net *net, struct socket *sock, int protocol)
  1124. {
  1125. struct sock *sk;
  1126. struct packet_sock *po;
  1127. __be16 proto = (__force __be16)protocol; /* weird, but documented */
  1128. int err;
  1129. if (!capable(CAP_NET_RAW))
  1130. return -EPERM;
  1131. if (sock->type != SOCK_DGRAM && sock->type != SOCK_RAW &&
  1132. sock->type != SOCK_PACKET)
  1133. return -ESOCKTNOSUPPORT;
  1134. sock->state = SS_UNCONNECTED;
  1135. err = -ENOBUFS;
  1136. sk = sk_alloc(net, PF_PACKET, GFP_KERNEL, &packet_proto);
  1137. if (sk == NULL)
  1138. goto out;
  1139. sock->ops = &packet_ops;
  1140. if (sock->type == SOCK_PACKET)
  1141. sock->ops = &packet_ops_spkt;
  1142. sock_init_data(sock, sk);
  1143. po = pkt_sk(sk);
  1144. sk->sk_family = PF_PACKET;
  1145. po->num = proto;
  1146. sk->sk_destruct = packet_sock_destruct;
  1147. sk_refcnt_debug_inc(sk);
  1148. /*
  1149. * Attach a protocol block
  1150. */
  1151. spin_lock_init(&po->bind_lock);
  1152. mutex_init(&po->pg_vec_lock);
  1153. po->prot_hook.func = packet_rcv;
  1154. if (sock->type == SOCK_PACKET)
  1155. po->prot_hook.func = packet_rcv_spkt;
  1156. po->prot_hook.af_packet_priv = sk;
  1157. if (proto) {
  1158. po->prot_hook.type = proto;
  1159. dev_add_pack(&po->prot_hook);
  1160. sock_hold(sk);
  1161. po->running = 1;
  1162. }
  1163. write_lock_bh(&net->packet.sklist_lock);
  1164. sk_add_node(sk, &net->packet.sklist);
  1165. sock_prot_inuse_add(net, &packet_proto, 1);
  1166. write_unlock_bh(&net->packet.sklist_lock);
  1167. return(0);
  1168. out:
  1169. return err;
  1170. }
  1171. /*
  1172. * Pull a packet from our receive queue and hand it to the user.
  1173. * If necessary we block.
  1174. */
  1175. static int packet_recvmsg(struct kiocb *iocb, struct socket *sock,
  1176. struct msghdr *msg, size_t len, int flags)
  1177. {
  1178. struct sock *sk = sock->sk;
  1179. struct sk_buff *skb;
  1180. int copied, err;
  1181. struct sockaddr_ll *sll;
  1182. err = -EINVAL;
  1183. if (flags & ~(MSG_PEEK|MSG_DONTWAIT|MSG_TRUNC|MSG_CMSG_COMPAT))
  1184. goto out;
  1185. #if 0
  1186. /* What error should we return now? EUNATTACH? */
  1187. if (pkt_sk(sk)->ifindex < 0)
  1188. return -ENODEV;
  1189. #endif
  1190. /*
  1191. * Call the generic datagram receiver. This handles all sorts
  1192. * of horrible races and re-entrancy so we can forget about it
  1193. * in the protocol layers.
  1194. *
  1195. * Now it will return ENETDOWN, if device have just gone down,
  1196. * but then it will block.
  1197. */
  1198. skb=skb_recv_datagram(sk,flags,flags&MSG_DONTWAIT,&err);
  1199. /*
  1200. * An error occurred so return it. Because skb_recv_datagram()
  1201. * handles the blocking we don't see and worry about blocking
  1202. * retries.
  1203. */
  1204. if (skb == NULL)
  1205. goto out;
  1206. /*
  1207. * If the address length field is there to be filled in, we fill
  1208. * it in now.
  1209. */
  1210. sll = &PACKET_SKB_CB(skb)->sa.ll;
  1211. if (sock->type == SOCK_PACKET)
  1212. msg->msg_namelen = sizeof(struct sockaddr_pkt);
  1213. else
  1214. msg->msg_namelen = sll->sll_halen + offsetof(struct sockaddr_ll, sll_addr);
  1215. /*
  1216. * You lose any data beyond the buffer you gave. If it worries a
  1217. * user program they can ask the device for its MTU anyway.
  1218. */
  1219. copied = skb->len;
  1220. if (copied > len)
  1221. {
  1222. copied=len;
  1223. msg->msg_flags|=MSG_TRUNC;
  1224. }
  1225. err = skb_copy_datagram_iovec(skb, 0, msg->msg_iov, copied);
  1226. if (err)
  1227. goto out_free;
  1228. sock_recv_timestamp(msg, sk, skb);
  1229. if (msg->msg_name)
  1230. memcpy(msg->msg_name, &PACKET_SKB_CB(skb)->sa,
  1231. msg->msg_namelen);
  1232. if (pkt_sk(sk)->auxdata) {
  1233. struct tpacket_auxdata aux;
  1234. aux.tp_status = TP_STATUS_USER;
  1235. if (skb->ip_summed == CHECKSUM_PARTIAL)
  1236. aux.tp_status |= TP_STATUS_CSUMNOTREADY;
  1237. aux.tp_len = PACKET_SKB_CB(skb)->origlen;
  1238. aux.tp_snaplen = skb->len;
  1239. aux.tp_mac = 0;
  1240. aux.tp_net = skb_network_offset(skb);
  1241. aux.tp_vlan_tci = skb->vlan_tci;
  1242. put_cmsg(msg, SOL_PACKET, PACKET_AUXDATA, sizeof(aux), &aux);
  1243. }
  1244. /*
  1245. * Free or return the buffer as appropriate. Again this
  1246. * hides all the races and re-entrancy issues from us.
  1247. */
  1248. err = (flags&MSG_TRUNC) ? skb->len : copied;
  1249. out_free:
  1250. skb_free_datagram(sk, skb);
  1251. out:
  1252. return err;
  1253. }
  1254. static int packet_getname_spkt(struct socket *sock, struct sockaddr *uaddr,
  1255. int *uaddr_len, int peer)
  1256. {
  1257. struct net_device *dev;
  1258. struct sock *sk = sock->sk;
  1259. if (peer)
  1260. return -EOPNOTSUPP;
  1261. uaddr->sa_family = AF_PACKET;
  1262. dev = dev_get_by_index(sock_net(sk), pkt_sk(sk)->ifindex);
  1263. if (dev) {
  1264. strlcpy(uaddr->sa_data, dev->name, 15);
  1265. dev_put(dev);
  1266. } else
  1267. memset(uaddr->sa_data, 0, 14);
  1268. *uaddr_len = sizeof(*uaddr);
  1269. return 0;
  1270. }
  1271. static int packet_getname(struct socket *sock, struct sockaddr *uaddr,
  1272. int *uaddr_len, int peer)
  1273. {
  1274. struct net_device *dev;
  1275. struct sock *sk = sock->sk;
  1276. struct packet_sock *po = pkt_sk(sk);
  1277. struct sockaddr_ll *sll = (struct sockaddr_ll*)uaddr;
  1278. if (peer)
  1279. return -EOPNOTSUPP;
  1280. sll->sll_family = AF_PACKET;
  1281. sll->sll_ifindex = po->ifindex;
  1282. sll->sll_protocol = po->num;
  1283. dev = dev_get_by_index(sock_net(sk), po->ifindex);
  1284. if (dev) {
  1285. sll->sll_hatype = dev->type;
  1286. sll->sll_halen = dev->addr_len;
  1287. memcpy(sll->sll_addr, dev->dev_addr, dev->addr_len);
  1288. dev_put(dev);
  1289. } else {
  1290. sll->sll_hatype = 0; /* Bad: we have no ARPHRD_UNSPEC */
  1291. sll->sll_halen = 0;
  1292. }
  1293. *uaddr_len = offsetof(struct sockaddr_ll, sll_addr) + sll->sll_halen;
  1294. return 0;
  1295. }
  1296. static int packet_dev_mc(struct net_device *dev, struct packet_mclist *i,
  1297. int what)
  1298. {
  1299. switch (i->type) {
  1300. case PACKET_MR_MULTICAST:
  1301. if (what > 0)
  1302. return dev_mc_add(dev, i->addr, i->alen, 0);
  1303. else
  1304. return dev_mc_delete(dev, i->addr, i->alen, 0);
  1305. break;
  1306. case PACKET_MR_PROMISC:
  1307. return dev_set_promiscuity(dev, what);
  1308. break;
  1309. case PACKET_MR_ALLMULTI:
  1310. return dev_set_allmulti(dev, what);
  1311. break;
  1312. case PACKET_MR_UNICAST:
  1313. if (what > 0)
  1314. return dev_unicast_add(dev, i->addr);
  1315. else
  1316. return dev_unicast_delete(dev, i->addr);
  1317. break;
  1318. default:;
  1319. }
  1320. return 0;
  1321. }
  1322. static void packet_dev_mclist(struct net_device *dev, struct packet_mclist *i, int what)
  1323. {
  1324. for ( ; i; i=i->next) {
  1325. if (i->ifindex == dev->ifindex)
  1326. packet_dev_mc(dev, i, what);
  1327. }
  1328. }
  1329. static int packet_mc_add(struct sock *sk, struct packet_mreq_max *mreq)
  1330. {
  1331. struct packet_sock *po = pkt_sk(sk);
  1332. struct packet_mclist *ml, *i;
  1333. struct net_device *dev;
  1334. int err;
  1335. rtnl_lock();
  1336. err = -ENODEV;
  1337. dev = __dev_get_by_index(sock_net(sk), mreq->mr_ifindex);
  1338. if (!dev)
  1339. goto done;
  1340. err = -EINVAL;
  1341. if (mreq->mr_alen > dev->addr_len)
  1342. goto done;
  1343. err = -ENOBUFS;
  1344. i = kmalloc(sizeof(*i), GFP_KERNEL);
  1345. if (i == NULL)
  1346. goto done;
  1347. err = 0;
  1348. for (ml = po->mclist; ml; ml = ml->next) {
  1349. if (ml->ifindex == mreq->mr_ifindex &&
  1350. ml->type == mreq->mr_type &&
  1351. ml->alen == mreq->mr_alen &&
  1352. memcmp(ml->addr, mreq->mr_address, ml->alen) == 0) {
  1353. ml->count++;
  1354. /* Free the new element ... */
  1355. kfree(i);
  1356. goto done;
  1357. }
  1358. }
  1359. i->type = mreq->mr_type;
  1360. i->ifindex = mreq->mr_ifindex;
  1361. i->alen = mreq->mr_alen;
  1362. memcpy(i->addr, mreq->mr_address, i->alen);
  1363. i->count = 1;
  1364. i->next = po->mclist;
  1365. po->mclist = i;
  1366. err = packet_dev_mc(dev, i, 1);
  1367. if (err) {
  1368. po->mclist = i->next;
  1369. kfree(i);
  1370. }
  1371. done:
  1372. rtnl_unlock();
  1373. return err;
  1374. }
  1375. static int packet_mc_drop(struct sock *sk, struct packet_mreq_max *mreq)
  1376. {
  1377. struct packet_mclist *ml, **mlp;
  1378. rtnl_lock();
  1379. for (mlp = &pkt_sk(sk)->mclist; (ml = *mlp) != NULL; mlp = &ml->next) {
  1380. if (ml->ifindex == mreq->mr_ifindex &&
  1381. ml->type == mreq->mr_type &&
  1382. ml->alen == mreq->mr_alen &&
  1383. memcmp(ml->addr, mreq->mr_address, ml->alen) == 0) {
  1384. if (--ml->count == 0) {
  1385. struct net_device *dev;
  1386. *mlp = ml->next;
  1387. dev = dev_get_by_index(sock_net(sk), ml->ifindex);
  1388. if (dev) {
  1389. packet_dev_mc(dev, ml, -1);
  1390. dev_put(dev);
  1391. }
  1392. kfree(ml);
  1393. }
  1394. rtnl_unlock();
  1395. return 0;
  1396. }
  1397. }
  1398. rtnl_unlock();
  1399. return -EADDRNOTAVAIL;
  1400. }
  1401. static void packet_flush_mclist(struct sock *sk)
  1402. {
  1403. struct packet_sock *po = pkt_sk(sk);
  1404. struct packet_mclist *ml;
  1405. if (!po->mclist)
  1406. return;
  1407. rtnl_lock();
  1408. while ((ml = po->mclist) != NULL) {
  1409. struct net_device *dev;
  1410. po->mclist = ml->next;
  1411. if ((dev = dev_get_by_index(sock_net(sk), ml->ifindex)) != NULL) {
  1412. packet_dev_mc(dev, ml, -1);
  1413. dev_put(dev);
  1414. }
  1415. kfree(ml);
  1416. }
  1417. rtnl_unlock();
  1418. }
  1419. static int
  1420. packet_setsockopt(struct socket *sock, int level, int optname, char __user *optval, int optlen)
  1421. {
  1422. struct sock *sk = sock->sk;
  1423. struct packet_sock *po = pkt_sk(sk);
  1424. int ret;
  1425. if (level != SOL_PACKET)
  1426. return -ENOPROTOOPT;
  1427. switch (optname) {
  1428. case PACKET_ADD_MEMBERSHIP:
  1429. case PACKET_DROP_MEMBERSHIP:
  1430. {
  1431. struct packet_mreq_max mreq;
  1432. int len = optlen;
  1433. memset(&mreq, 0, sizeof(mreq));
  1434. if (len < sizeof(struct packet_mreq))
  1435. return -EINVAL;
  1436. if (len > sizeof(mreq))
  1437. len = sizeof(mreq);
  1438. if (copy_from_user(&mreq,optval,len))
  1439. return -EFAULT;
  1440. if (len < (mreq.mr_alen + offsetof(struct packet_mreq, mr_address)))
  1441. return -EINVAL;
  1442. if (optname == PACKET_ADD_MEMBERSHIP)
  1443. ret = packet_mc_add(sk, &mreq);
  1444. else
  1445. ret = packet_mc_drop(sk, &mreq);
  1446. return ret;
  1447. }
  1448. #ifdef CONFIG_PACKET_MMAP
  1449. case PACKET_RX_RING:
  1450. case PACKET_TX_RING:
  1451. {
  1452. struct tpacket_req req;
  1453. if (optlen<sizeof(req))
  1454. return -EINVAL;
  1455. if (copy_from_user(&req,optval,sizeof(req)))
  1456. return -EFAULT;
  1457. return packet_set_ring(sk, &req, 0, optname == PACKET_TX_RING);
  1458. }
  1459. case PACKET_COPY_THRESH:
  1460. {
  1461. int val;
  1462. if (optlen!=sizeof(val))
  1463. return -EINVAL;
  1464. if (copy_from_user(&val,optval,sizeof(val)))
  1465. return -EFAULT;
  1466. pkt_sk(sk)->copy_thresh = val;
  1467. return 0;
  1468. }
  1469. case PACKET_VERSION:
  1470. {
  1471. int val;
  1472. if (optlen != sizeof(val))
  1473. return -EINVAL;
  1474. if (po->rx_ring.pg_vec || po->tx_ring.pg_vec)
  1475. return -EBUSY;
  1476. if (copy_from_user(&val, optval, sizeof(val)))
  1477. return -EFAULT;
  1478. switch (val) {
  1479. case TPACKET_V1:
  1480. case TPACKET_V2:
  1481. po->tp_version = val;
  1482. return 0;
  1483. default:
  1484. return -EINVAL;
  1485. }
  1486. }
  1487. case PACKET_RESERVE:
  1488. {
  1489. unsigned int val;
  1490. if (optlen != sizeof(val))
  1491. return -EINVAL;
  1492. if (po->rx_ring.pg_vec || po->tx_ring.pg_vec)
  1493. return -EBUSY;
  1494. if (copy_from_user(&val, optval, sizeof(val)))
  1495. return -EFAULT;
  1496. po->tp_reserve = val;
  1497. return 0;
  1498. }
  1499. case PACKET_LOSS:
  1500. {
  1501. unsigned int val;
  1502. if (optlen != sizeof(val))
  1503. return -EINVAL;
  1504. if (po->rx_ring.pg_vec || po->tx_ring.pg_vec)
  1505. return -EBUSY;
  1506. if (copy_from_user(&val, optval, sizeof(val)))
  1507. return -EFAULT;
  1508. po->tp_loss = !!val;
  1509. return 0;
  1510. }
  1511. #endif
  1512. case PACKET_AUXDATA:
  1513. {
  1514. int val;
  1515. if (optlen < sizeof(val))
  1516. return -EINVAL;
  1517. if (copy_from_user(&val, optval, sizeof(val)))
  1518. return -EFAULT;
  1519. po->auxdata = !!val;
  1520. return 0;
  1521. }
  1522. case PACKET_ORIGDEV:
  1523. {
  1524. int val;
  1525. if (optlen < sizeof(val))
  1526. return -EINVAL;
  1527. if (copy_from_user(&val, optval, sizeof(val)))
  1528. return -EFAULT;
  1529. po->origdev = !!val;
  1530. return 0;
  1531. }
  1532. default:
  1533. return -ENOPROTOOPT;
  1534. }
  1535. }
  1536. static int packet_getsockopt(struct socket *sock, int level, int optname,
  1537. char __user *optval, int __user *optlen)
  1538. {
  1539. int len;
  1540. int val;
  1541. struct sock *sk = sock->sk;
  1542. struct packet_sock *po = pkt_sk(sk);
  1543. void *data;
  1544. struct tpacket_stats st;
  1545. if (level != SOL_PACKET)
  1546. return -ENOPROTOOPT;
  1547. if (get_user(len, optlen))
  1548. return -EFAULT;
  1549. if (len < 0)
  1550. return -EINVAL;
  1551. switch (optname) {
  1552. case PACKET_STATISTICS:
  1553. if (len > sizeof(struct tpacket_stats))
  1554. len = sizeof(struct tpacket_stats);
  1555. spin_lock_bh(&sk->sk_receive_queue.lock);
  1556. st = po->stats;
  1557. memset(&po->stats, 0, sizeof(st));
  1558. spin_unlock_bh(&sk->sk_receive_queue.lock);
  1559. st.tp_packets += st.tp_drops;
  1560. data = &st;
  1561. break;
  1562. case PACKET_AUXDATA:
  1563. if (len > sizeof(int))
  1564. len = sizeof(int);
  1565. val = po->auxdata;
  1566. data = &val;
  1567. break;
  1568. case PACKET_ORIGDEV:
  1569. if (len > sizeof(int))
  1570. len = sizeof(int);
  1571. val = po->origdev;
  1572. data = &val;
  1573. break;
  1574. #ifdef CONFIG_PACKET_MMAP
  1575. case PACKET_VERSION:
  1576. if (len > sizeof(int))
  1577. len = sizeof(int);
  1578. val = po->tp_version;
  1579. data = &val;
  1580. break;
  1581. case PACKET_HDRLEN:
  1582. if (len > sizeof(int))
  1583. len = sizeof(int);
  1584. if (copy_from_user(&val, optval, len))
  1585. return -EFAULT;
  1586. switch (val) {
  1587. case TPACKET_V1:
  1588. val = sizeof(struct tpacket_hdr);
  1589. break;
  1590. case TPACKET_V2:
  1591. val = sizeof(struct tpacket2_hdr);
  1592. break;
  1593. default:
  1594. return -EINVAL;
  1595. }
  1596. data = &val;
  1597. break;
  1598. case PACKET_RESERVE:
  1599. if (len > sizeof(unsigned int))
  1600. len = sizeof(unsigned int);
  1601. val = po->tp_reserve;
  1602. data = &val;
  1603. break;
  1604. case PACKET_LOSS:
  1605. if (len > sizeof(unsigned int))
  1606. len = sizeof(unsigned int);
  1607. val = po->tp_loss;
  1608. data = &val;
  1609. break;
  1610. #endif
  1611. default:
  1612. return -ENOPROTOOPT;
  1613. }
  1614. if (put_user(len, optlen))
  1615. return -EFAULT;
  1616. if (copy_to_user(optval, data, len))
  1617. return -EFAULT;
  1618. return 0;
  1619. }
  1620. static int packet_notifier(struct notifier_block *this, unsigned long msg, void *data)
  1621. {
  1622. struct sock *sk;
  1623. struct hlist_node *node;
  1624. struct net_device *dev = data;
  1625. struct net *net = dev_net(dev);
  1626. read_lock(&net->packet.sklist_lock);
  1627. sk_for_each(sk, node, &net->packet.sklist) {
  1628. struct packet_sock *po = pkt_sk(sk);
  1629. switch (msg) {
  1630. case NETDEV_UNREGISTER:
  1631. if (po->mclist)
  1632. packet_dev_mclist(dev, po->mclist, -1);
  1633. /* fallthrough */
  1634. case NETDEV_DOWN:
  1635. if (dev->ifindex == po->ifindex) {
  1636. spin_lock(&po->bind_lock);
  1637. if (po->running) {
  1638. __dev_remove_pack(&po->prot_hook);
  1639. __sock_put(sk);
  1640. po->running = 0;
  1641. sk->sk_err = ENETDOWN;
  1642. if (!sock_flag(sk, SOCK_DEAD))
  1643. sk->sk_error_report(sk);
  1644. }
  1645. if (msg == NETDEV_UNREGISTER) {
  1646. po->ifindex = -1;
  1647. po->prot_hook.dev = NULL;
  1648. }
  1649. spin_unlock(&po->bind_lock);
  1650. }
  1651. break;
  1652. case NETDEV_UP:
  1653. spin_lock(&po->bind_lock);
  1654. if (dev->ifindex == po->ifindex && po->num &&
  1655. !po->running) {
  1656. dev_add_pack(&po->prot_hook);
  1657. sock_hold(sk);
  1658. po->running = 1;
  1659. }
  1660. spin_unlock(&po->bind_lock);
  1661. break;
  1662. }
  1663. }
  1664. read_unlock(&net->packet.sklist_lock);
  1665. return NOTIFY_DONE;
  1666. }
  1667. static int packet_ioctl(struct socket *sock, unsigned int cmd,
  1668. unsigned long arg)
  1669. {
  1670. struct sock *sk = sock->sk;
  1671. switch (cmd) {
  1672. case SIOCOUTQ:
  1673. {
  1674. int amount = sk_wmem_alloc_get(sk);
  1675. return put_user(amount, (int __user *)arg);
  1676. }
  1677. case SIOCINQ:
  1678. {
  1679. struct sk_buff *skb;
  1680. int amount = 0;
  1681. spin_lock_bh(&sk->sk_receive_queue.lock);
  1682. skb = skb_peek(&sk->sk_receive_queue);
  1683. if (skb)
  1684. amount = skb->len;
  1685. spin_unlock_bh(&sk->sk_receive_queue.lock);
  1686. return put_user(amount, (int __user *)arg);
  1687. }
  1688. case SIOCGSTAMP:
  1689. return sock_get_timestamp(sk, (struct timeval __user *)arg);
  1690. case SIOCGSTAMPNS:
  1691. return sock_get_timestampns(sk, (struct timespec __user *)arg);
  1692. #ifdef CONFIG_INET
  1693. case SIOCADDRT:
  1694. case SIOCDELRT:
  1695. case SIOCDARP:
  1696. case SIOCGARP:
  1697. case SIOCSARP:
  1698. case SIOCGIFADDR:
  1699. case SIOCSIFADDR:
  1700. case SIOCGIFBRDADDR:
  1701. case SIOCSIFBRDADDR:
  1702. case SIOCGIFNETMASK:
  1703. case SIOCSIFNETMASK:
  1704. case SIOCGIFDSTADDR:
  1705. case SIOCSIFDSTADDR:
  1706. case SIOCSIFFLAGS:
  1707. if (!net_eq(sock_net(sk), &init_net))
  1708. return -ENOIOCTLCMD;
  1709. return inet_dgram_ops.ioctl(sock, cmd, arg);
  1710. #endif
  1711. default:
  1712. return -ENOIOCTLCMD;
  1713. }
  1714. return 0;
  1715. }
  1716. #ifndef CONFIG_PACKET_MMAP
  1717. #define packet_mmap sock_no_mmap
  1718. #define packet_poll datagram_poll
  1719. #else
  1720. static unsigned int packet_poll(struct file * file, struct socket *sock,
  1721. poll_table *wait)
  1722. {
  1723. struct sock *sk = sock->sk;
  1724. struct packet_sock *po = pkt_sk(sk);
  1725. unsigned int mask = datagram_poll(file, sock, wait);
  1726. spin_lock_bh(&sk->sk_receive_queue.lock);
  1727. if (po->rx_ring.pg_vec) {
  1728. if (!packet_previous_frame(po, &po->rx_ring, TP_STATUS_KERNEL))
  1729. mask |= POLLIN | POLLRDNORM;
  1730. }
  1731. spin_unlock_bh(&sk->sk_receive_queue.lock);
  1732. spin_lock_bh(&sk->sk_write_queue.lock);
  1733. if (po->tx_ring.pg_vec) {
  1734. if (packet_current_frame(po, &po->tx_ring, TP_STATUS_AVAILABLE))
  1735. mask |= POLLOUT | POLLWRNORM;
  1736. }
  1737. spin_unlock_bh(&sk->sk_write_queue.lock);
  1738. return mask;
  1739. }
  1740. /* Dirty? Well, I still did not learn better way to account
  1741. * for user mmaps.
  1742. */
  1743. static void packet_mm_open(struct vm_area_struct *vma)
  1744. {
  1745. struct file *file = vma->vm_file;
  1746. struct socket * sock = file->private_data;
  1747. struct sock *sk = sock->sk;
  1748. if (sk)
  1749. atomic_inc(&pkt_sk(sk)->mapped);
  1750. }
  1751. static void packet_mm_close(struct vm_area_struct *vma)
  1752. {
  1753. struct file *file = vma->vm_file;
  1754. struct socket * sock = file->private_data;
  1755. struct sock *sk = sock->sk;
  1756. if (sk)
  1757. atomic_dec(&pkt_sk(sk)->mapped);
  1758. }
  1759. static struct vm_operations_struct packet_mmap_ops = {
  1760. .open = packet_mm_open,
  1761. .close =packet_mm_close,
  1762. };
  1763. static void free_pg_vec(char **pg_vec, unsigned int order, unsigned int len)
  1764. {
  1765. int i;
  1766. for (i = 0; i < len; i++) {
  1767. if (likely(pg_vec[i]))
  1768. free_pages((unsigned long) pg_vec[i], order);
  1769. }
  1770. kfree(pg_vec);
  1771. }
  1772. static inline char *alloc_one_pg_vec_page(unsigned long order)
  1773. {
  1774. gfp_t gfp_flags = GFP_KERNEL | __GFP_COMP | __GFP_ZERO | __GFP_NOWARN;
  1775. return (char *) __get_free_pages(gfp_flags, order);
  1776. }
  1777. static char **alloc_pg_vec(struct tpacket_req *req, int order)
  1778. {
  1779. unsigned int block_nr = req->tp_block_nr;
  1780. char **pg_vec;
  1781. int i;
  1782. pg_vec = kzalloc(block_nr * sizeof(char *), GFP_KERNEL);
  1783. if (unlikely(!pg_vec))
  1784. goto out;
  1785. for (i = 0; i < block_nr; i++) {
  1786. pg_vec[i] = alloc_one_pg_vec_page(order);
  1787. if (unlikely(!pg_vec[i]))
  1788. goto out_free_pgvec;
  1789. }
  1790. out:
  1791. return pg_vec;
  1792. out_free_pgvec:
  1793. free_pg_vec(pg_vec, order, block_nr);
  1794. pg_vec = NULL;
  1795. goto out;
  1796. }
  1797. static int packet_set_ring(struct sock *sk, struct tpacket_req *req,
  1798. int closing, int tx_ring)
  1799. {
  1800. char **pg_vec = NULL;
  1801. struct packet_sock *po = pkt_sk(sk);
  1802. int was_running, order = 0;
  1803. struct packet_ring_buffer *rb;
  1804. struct sk_buff_head *rb_queue;
  1805. __be16 num;
  1806. int err;
  1807. rb = tx_ring ? &po->tx_ring : &po->rx_ring;
  1808. rb_queue = tx_ring ? &sk->sk_write_queue : &sk->sk_receive_queue;
  1809. err = -EBUSY;
  1810. if (!closing) {
  1811. if (atomic_read(&po->mapped))
  1812. goto out;
  1813. if (atomic_read(&rb->pending))
  1814. goto out;
  1815. }
  1816. if (req->tp_block_nr) {
  1817. /* Sanity tests and some calculations */
  1818. err = -EBUSY;
  1819. if (unlikely(rb->pg_vec))
  1820. goto out;
  1821. switch (po->tp_version) {
  1822. case TPACKET_V1:
  1823. po->tp_hdrlen = TPACKET_HDRLEN;
  1824. break;
  1825. case TPACKET_V2:
  1826. po->tp_hdrlen = TPACKET2_HDRLEN;
  1827. break;
  1828. }
  1829. err = -EINVAL;
  1830. if (unlikely((int)req->tp_block_size <= 0))
  1831. goto out;
  1832. if (unlikely(req->tp_block_size & (PAGE_SIZE - 1)))
  1833. goto out;
  1834. if (unlikely(req->tp_frame_size < po->tp_hdrlen +
  1835. po->tp_reserve))
  1836. goto out;
  1837. if (unlikely(req->tp_frame_size & (TPACKET_ALIGNMENT - 1)))
  1838. goto out;
  1839. rb->frames_per_block = req->tp_block_size/req->tp_frame_size;
  1840. if (unlikely(rb->frames_per_block <= 0))
  1841. goto out;
  1842. if (unlikely((rb->frames_per_block * req->tp_block_nr) !=
  1843. req->tp_frame_nr))
  1844. goto out;
  1845. err = -ENOMEM;
  1846. order = get_order(req->tp_block_size);
  1847. pg_vec = alloc_pg_vec(req, order);
  1848. if (unlikely(!pg_vec))
  1849. goto out;
  1850. }
  1851. /* Done */
  1852. else {
  1853. err = -EINVAL;
  1854. if (unlikely(req->tp_frame_nr))
  1855. goto out;
  1856. }
  1857. lock_sock(sk);
  1858. /* Detach socket from network */
  1859. spin_lock(&po->bind_lock);
  1860. was_running = po->running;
  1861. num = po->num;
  1862. if (was_running) {
  1863. __dev_remove_pack(&po->prot_hook);
  1864. po->num = 0;
  1865. po->running = 0;
  1866. __sock_put(sk);
  1867. }
  1868. spin_unlock(&po->bind_lock);
  1869. synchronize_net();
  1870. err = -EBUSY;
  1871. mutex_lock(&po->pg_vec_lock);
  1872. if (closing || atomic_read(&po->mapped) == 0) {
  1873. err = 0;
  1874. #define XC(a, b) ({ __typeof__ ((a)) __t; __t = (a); (a) = (b); __t; })
  1875. spin_lock_bh(&rb_queue->lock);
  1876. pg_vec = XC(rb->pg_vec, pg_vec);
  1877. rb->frame_max = (req->tp_frame_nr - 1);
  1878. rb->head = 0;
  1879. rb->frame_size = req->tp_frame_size;
  1880. spin_unlock_bh(&rb_queue->lock);
  1881. order = XC(rb->pg_vec_order, order);
  1882. req->tp_block_nr = XC(rb->pg_vec_len, req->tp_block_nr);
  1883. rb->pg_vec_pages = req->tp_block_size/PAGE_SIZE;
  1884. po->prot_hook.func = (po->rx_ring.pg_vec) ?
  1885. tpacket_rcv : packet_rcv;
  1886. skb_queue_purge(rb_queue);
  1887. #undef XC
  1888. if (atomic_read(&po->mapped))
  1889. printk(KERN_DEBUG "packet_mmap: vma is busy: %d\n",
  1890. atomic_read(&po->mapped));
  1891. }
  1892. mutex_unlock(&po->pg_vec_lock);
  1893. spin_lock(&po->bind_lock);
  1894. if (was_running && !po->running) {
  1895. sock_hold(sk);
  1896. po->running = 1;
  1897. po->num = num;
  1898. dev_add_pack(&po->prot_hook);
  1899. }
  1900. spin_unlock(&po->bind_lock);
  1901. release_sock(sk);
  1902. if (pg_vec)
  1903. free_pg_vec(pg_vec, order, req->tp_block_nr);
  1904. out:
  1905. return err;
  1906. }
  1907. static int packet_mmap(struct file *file, struct socket *sock,
  1908. struct vm_area_struct *vma)
  1909. {
  1910. struct sock *sk = sock->sk;
  1911. struct packet_sock *po = pkt_sk(sk);
  1912. unsigned long size, expected_size;
  1913. struct packet_ring_buffer *rb;
  1914. unsigned long start;
  1915. int err = -EINVAL;
  1916. int i;
  1917. if (vma->vm_pgoff)
  1918. return -EINVAL;
  1919. mutex_lock(&po->pg_vec_lock);
  1920. expected_size = 0;
  1921. for (rb = &po->rx_ring; rb <= &po->tx_ring; rb++) {
  1922. if (rb->pg_vec) {
  1923. expected_size += rb->pg_vec_len
  1924. * rb->pg_vec_pages
  1925. * PAGE_SIZE;
  1926. }
  1927. }
  1928. if (expected_size == 0)
  1929. goto out;
  1930. size = vma->vm_end - vma->vm_start;
  1931. if (size != expected_size)
  1932. goto out;
  1933. start = vma->vm_start;
  1934. for (rb = &po->rx_ring; rb <= &po->tx_ring; rb++) {
  1935. if (rb->pg_vec == NULL)
  1936. continue;
  1937. for (i = 0; i < rb->pg_vec_len; i++) {
  1938. struct page *page = virt_to_page(rb->pg_vec[i]);
  1939. int pg_num;
  1940. for (pg_num = 0; pg_num < rb->pg_vec_pages;
  1941. pg_num++,page++) {
  1942. err = vm_insert_page(vma, start, page);
  1943. if (unlikely(err))
  1944. goto out;
  1945. start += PAGE_SIZE;
  1946. }
  1947. }
  1948. }
  1949. atomic_inc(&po->mapped);
  1950. vma->vm_ops = &packet_mmap_ops;
  1951. err = 0;
  1952. out:
  1953. mutex_unlock(&po->pg_vec_lock);
  1954. return err;
  1955. }
  1956. #endif
  1957. static const struct proto_ops packet_ops_spkt = {
  1958. .family = PF_PACKET,
  1959. .owner = THIS_MODULE,
  1960. .release = packet_release,
  1961. .bind = packet_bind_spkt,
  1962. .connect = sock_no_connect,
  1963. .socketpair = sock_no_socketpair,
  1964. .accept = sock_no_accept,
  1965. .getname = packet_getname_spkt,
  1966. .poll = datagram_poll,
  1967. .ioctl = packet_ioctl,
  1968. .listen = sock_no_listen,
  1969. .shutdown = sock_no_shutdown,
  1970. .setsockopt = sock_no_setsockopt,
  1971. .getsockopt = sock_no_getsockopt,
  1972. .sendmsg = packet_sendmsg_spkt,
  1973. .recvmsg = packet_recvmsg,
  1974. .mmap = sock_no_mmap,
  1975. .sendpage = sock_no_sendpage,
  1976. };
  1977. static const struct proto_ops packet_ops = {
  1978. .family = PF_PACKET,
  1979. .owner = THIS_MODULE,
  1980. .release = packet_release,
  1981. .bind = packet_bind,
  1982. .connect = sock_no_connect,
  1983. .socketpair = sock_no_socketpair,
  1984. .accept = sock_no_accept,
  1985. .getname = packet_getname,
  1986. .poll = packet_poll,
  1987. .ioctl = packet_ioctl,
  1988. .listen = sock_no_listen,
  1989. .shutdown = sock_no_shutdown,
  1990. .setsockopt = packet_setsockopt,
  1991. .getsockopt = packet_getsockopt,
  1992. .sendmsg = packet_sendmsg,
  1993. .recvmsg = packet_recvmsg,
  1994. .mmap = packet_mmap,
  1995. .sendpage = sock_no_sendpage,
  1996. };
  1997. static struct net_proto_family packet_family_ops = {
  1998. .family = PF_PACKET,
  1999. .create = packet_create,
  2000. .owner = THIS_MODULE,
  2001. };
  2002. static struct notifier_block packet_netdev_notifier = {
  2003. .notifier_call =packet_notifier,
  2004. };
  2005. #ifdef CONFIG_PROC_FS
  2006. static inline struct sock *packet_seq_idx(struct net *net, loff_t off)
  2007. {
  2008. struct sock *s;
  2009. struct hlist_node *node;
  2010. sk_for_each(s, node, &net->packet.sklist) {
  2011. if (!off--)
  2012. return s;
  2013. }
  2014. return NULL;
  2015. }
  2016. static void *packet_seq_start(struct seq_file *seq, loff_t *pos)
  2017. __acquires(seq_file_net(seq)->packet.sklist_lock)
  2018. {
  2019. struct net *net = seq_file_net(seq);
  2020. read_lock(&net->packet.sklist_lock);
  2021. return *pos ? packet_seq_idx(net, *pos - 1) : SEQ_START_TOKEN;
  2022. }
  2023. static void *packet_seq_next(struct seq_file *seq, void *v, loff_t *pos)
  2024. {
  2025. struct net *net = seq_file_net(seq);
  2026. ++*pos;
  2027. return (v == SEQ_START_TOKEN)
  2028. ? sk_head(&net->packet.sklist)
  2029. : sk_next((struct sock*)v) ;
  2030. }
  2031. static void packet_seq_stop(struct seq_file *seq, void *v)
  2032. __releases(seq_file_net(seq)->packet.sklist_lock)
  2033. {
  2034. struct net *net = seq_file_net(seq);
  2035. read_unlock(&net->packet.sklist_lock);
  2036. }
  2037. static int packet_seq_show(struct seq_file *seq, void *v)
  2038. {
  2039. if (v == SEQ_START_TOKEN)
  2040. seq_puts(seq, "sk RefCnt Type Proto Iface R Rmem User Inode\n");
  2041. else {
  2042. struct sock *s = v;
  2043. const struct packet_sock *po = pkt_sk(s);
  2044. seq_printf(seq,
  2045. "%p %-6d %-4d %04x %-5d %1d %-6u %-6u %-6lu\n",
  2046. s,
  2047. atomic_read(&s->sk_refcnt),
  2048. s->sk_type,
  2049. ntohs(po->num),
  2050. po->ifindex,
  2051. po->running,
  2052. atomic_read(&s->sk_rmem_alloc),
  2053. sock_i_uid(s),
  2054. sock_i_ino(s) );
  2055. }
  2056. return 0;
  2057. }
  2058. static const struct seq_operations packet_seq_ops = {
  2059. .start = packet_seq_start,
  2060. .next = packet_seq_next,
  2061. .stop = packet_seq_stop,
  2062. .show = packet_seq_show,
  2063. };
  2064. static int packet_seq_open(struct inode *inode, struct file *file)
  2065. {
  2066. return seq_open_net(inode, file, &packet_seq_ops,
  2067. sizeof(struct seq_net_private));
  2068. }
  2069. static const struct file_operations packet_seq_fops = {
  2070. .owner = THIS_MODULE,
  2071. .open = packet_seq_open,
  2072. .read = seq_read,
  2073. .llseek = seq_lseek,
  2074. .release = seq_release_net,
  2075. };
  2076. #endif
  2077. static int packet_net_init(struct net *net)
  2078. {
  2079. rwlock_init(&net->packet.sklist_lock);
  2080. INIT_HLIST_HEAD(&net->packet.sklist);
  2081. if (!proc_net_fops_create(net, "packet", 0, &packet_seq_fops))
  2082. return -ENOMEM;
  2083. return 0;
  2084. }
  2085. static void packet_net_exit(struct net *net)
  2086. {
  2087. proc_net_remove(net, "packet");
  2088. }
  2089. static struct pernet_operations packet_net_ops = {
  2090. .init = packet_net_init,
  2091. .exit = packet_net_exit,
  2092. };
  2093. static void __exit packet_exit(void)
  2094. {
  2095. unregister_netdevice_notifier(&packet_netdev_notifier);
  2096. unregister_pernet_subsys(&packet_net_ops);
  2097. sock_unregister(PF_PACKET);
  2098. proto_unregister(&packet_proto);
  2099. }
  2100. static int __init packet_init(void)
  2101. {
  2102. int rc = proto_register(&packet_proto, 0);
  2103. if (rc != 0)
  2104. goto out;
  2105. sock_register(&packet_family_ops);
  2106. register_pernet_subsys(&packet_net_ops);
  2107. register_netdevice_notifier(&packet_netdev_notifier);
  2108. out:
  2109. return rc;
  2110. }
  2111. module_init(packet_init);
  2112. module_exit(packet_exit);
  2113. MODULE_LICENSE("GPL");
  2114. MODULE_ALIAS_NETPROTO(PF_PACKET);