connector.h 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*
  2. * connector.h
  3. *
  4. * 2004-2005 Copyright (c) Evgeniy Polyakov <zbr@ioremap.net>
  5. * All rights reserved.
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  20. */
  21. #ifndef __CONNECTOR_H
  22. #define __CONNECTOR_H
  23. #include <linux/atomic.h>
  24. #include <linux/list.h>
  25. #include <linux/workqueue.h>
  26. #include <net/sock.h>
  27. #include <uapi/linux/connector.h>
  28. #define CN_CBQ_NAMELEN 32
  29. struct cn_queue_dev {
  30. atomic_t refcnt;
  31. unsigned char name[CN_CBQ_NAMELEN];
  32. struct list_head queue_list;
  33. spinlock_t queue_lock;
  34. struct sock *nls;
  35. };
  36. struct cn_callback_id {
  37. unsigned char name[CN_CBQ_NAMELEN];
  38. struct cb_id id;
  39. };
  40. struct cn_callback_entry {
  41. struct list_head callback_entry;
  42. atomic_t refcnt;
  43. struct cn_queue_dev *pdev;
  44. struct cn_callback_id id;
  45. void (*callback) (struct cn_msg *, struct netlink_skb_parms *);
  46. u32 seq, group;
  47. };
  48. struct cn_dev {
  49. struct cb_id id;
  50. u32 seq, groups;
  51. struct sock *nls;
  52. void (*input) (struct sk_buff *skb);
  53. struct cn_queue_dev *cbdev;
  54. };
  55. int cn_add_callback(struct cb_id *id, const char *name,
  56. void (*callback)(struct cn_msg *, struct netlink_skb_parms *));
  57. void cn_del_callback(struct cb_id *);
  58. int cn_netlink_send_mult(struct cn_msg *msg, u16 len, u32 portid, u32 group, gfp_t gfp_mask);
  59. int cn_netlink_send(struct cn_msg *msg, u32 portid, u32 group, gfp_t gfp_mask);
  60. int cn_queue_add_callback(struct cn_queue_dev *dev, const char *name,
  61. struct cb_id *id,
  62. void (*callback)(struct cn_msg *, struct netlink_skb_parms *));
  63. void cn_queue_del_callback(struct cn_queue_dev *dev, struct cb_id *id);
  64. void cn_queue_release_callback(struct cn_callback_entry *);
  65. struct cn_queue_dev *cn_queue_alloc_dev(const char *name, struct sock *);
  66. void cn_queue_free_dev(struct cn_queue_dev *dev);
  67. int cn_cb_equal(struct cb_id *, struct cb_id *);
  68. #endif /* __CONNECTOR_H */