p8022.c 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /*
  2. * NET3: Support for 802.2 demultiplexing off Ethernet (Token ring
  3. * is kept separate see p8022tr.c)
  4. * This program is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU General Public License
  6. * as published by the Free Software Foundation; either version
  7. * 2 of the License, or (at your option) any later version.
  8. *
  9. * Demultiplex 802.2 encoded protocols. We match the entry by the
  10. * SSAP/DSAP pair and then deliver to the registered datalink that
  11. * matches. The control byte is ignored and handling of such items
  12. * is up to the routine passed the frame.
  13. *
  14. * Unlike the 802.3 datalink we have a list of 802.2 entries as
  15. * there are multiple protocols to demux. The list is currently
  16. * short (3 or 4 entries at most). The current demux assumes this.
  17. */
  18. #include <linux/module.h>
  19. #include <linux/netdevice.h>
  20. #include <linux/skbuff.h>
  21. #include <linux/slab.h>
  22. #include <net/datalink.h>
  23. #include <linux/mm.h>
  24. #include <linux/in.h>
  25. #include <linux/init.h>
  26. #include <net/llc.h>
  27. #include <net/p8022.h>
  28. static int p8022_request(struct datalink_proto *dl, struct sk_buff *skb,
  29. unsigned char *dest)
  30. {
  31. llc_build_and_send_ui_pkt(dl->sap, skb, dest, dl->sap->laddr.lsap);
  32. return 0;
  33. }
  34. struct datalink_proto *register_8022_client(unsigned char type,
  35. int (*func)(struct sk_buff *skb,
  36. struct net_device *dev,
  37. struct packet_type *pt,
  38. struct net_device *orig_dev))
  39. {
  40. struct datalink_proto *proto;
  41. proto = kmalloc(sizeof(*proto), GFP_ATOMIC);
  42. if (proto) {
  43. proto->type[0] = type;
  44. proto->header_length = 3;
  45. proto->request = p8022_request;
  46. proto->sap = llc_sap_open(type, func);
  47. if (!proto->sap) {
  48. kfree(proto);
  49. proto = NULL;
  50. }
  51. }
  52. return proto;
  53. }
  54. void unregister_8022_client(struct datalink_proto *proto)
  55. {
  56. llc_sap_put(proto->sap);
  57. kfree(proto);
  58. }
  59. EXPORT_SYMBOL(register_8022_client);
  60. EXPORT_SYMBOL(unregister_8022_client);
  61. MODULE_LICENSE("GPL");