diag.c 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * net/dccp/diag.c
  3. *
  4. * An implementation of the DCCP protocol
  5. * Arnaldo Carvalho de Melo <acme@mandriva.com>
  6. *
  7. * This program is free software; you can redistribute it and/or modify it
  8. * under the terms of the GNU General Public License version 2 as
  9. * published by the Free Software Foundation.
  10. */
  11. #include <linux/module.h>
  12. #include <linux/inet_diag.h>
  13. #include "ccid.h"
  14. #include "dccp.h"
  15. static void dccp_get_info(struct sock *sk, struct tcp_info *info)
  16. {
  17. struct dccp_sock *dp = dccp_sk(sk);
  18. const struct inet_connection_sock *icsk = inet_csk(sk);
  19. memset(info, 0, sizeof(*info));
  20. info->tcpi_state = sk->sk_state;
  21. info->tcpi_retransmits = icsk->icsk_retransmits;
  22. info->tcpi_probes = icsk->icsk_probes_out;
  23. info->tcpi_backoff = icsk->icsk_backoff;
  24. info->tcpi_pmtu = icsk->icsk_pmtu_cookie;
  25. if (dp->dccps_hc_rx_ackvec != NULL)
  26. info->tcpi_options |= TCPI_OPT_SACK;
  27. if (dp->dccps_hc_rx_ccid != NULL)
  28. ccid_hc_rx_get_info(dp->dccps_hc_rx_ccid, sk, info);
  29. if (dp->dccps_hc_tx_ccid != NULL)
  30. ccid_hc_tx_get_info(dp->dccps_hc_tx_ccid, sk, info);
  31. }
  32. static void dccp_diag_get_info(struct sock *sk, struct inet_diag_msg *r,
  33. void *_info)
  34. {
  35. r->idiag_rqueue = r->idiag_wqueue = 0;
  36. if (_info != NULL)
  37. dccp_get_info(sk, _info);
  38. }
  39. static void dccp_diag_dump(struct sk_buff *skb, struct netlink_callback *cb,
  40. const struct inet_diag_req_v2 *r, struct nlattr *bc)
  41. {
  42. inet_diag_dump_icsk(&dccp_hashinfo, skb, cb, r, bc);
  43. }
  44. static int dccp_diag_dump_one(struct sk_buff *in_skb,
  45. const struct nlmsghdr *nlh,
  46. const struct inet_diag_req_v2 *req)
  47. {
  48. return inet_diag_dump_one_icsk(&dccp_hashinfo, in_skb, nlh, req);
  49. }
  50. static const struct inet_diag_handler dccp_diag_handler = {
  51. .dump = dccp_diag_dump,
  52. .dump_one = dccp_diag_dump_one,
  53. .idiag_get_info = dccp_diag_get_info,
  54. .idiag_type = IPPROTO_DCCP,
  55. .idiag_info_size = sizeof(struct tcp_info),
  56. };
  57. static int __init dccp_diag_init(void)
  58. {
  59. return inet_diag_register(&dccp_diag_handler);
  60. }
  61. static void __exit dccp_diag_fini(void)
  62. {
  63. inet_diag_unregister(&dccp_diag_handler);
  64. }
  65. module_init(dccp_diag_init);
  66. module_exit(dccp_diag_fini);
  67. MODULE_LICENSE("GPL");
  68. MODULE_AUTHOR("Arnaldo Carvalho de Melo <acme@mandriva.com>");
  69. MODULE_DESCRIPTION("DCCP inet_diag handler");
  70. MODULE_ALIAS_NET_PF_PROTO_TYPE(PF_NETLINK, NETLINK_SOCK_DIAG, 2-33 /* AF_INET - IPPROTO_DCCP */);