af_rxrpc.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /* SPDX-License-Identifier: GPL-2.0-or-later */
  2. /* RxRPC kernel service interface definitions
  3. *
  4. * Copyright (C) 2007 Red Hat, Inc. All Rights Reserved.
  5. * Written by David Howells (dhowells@redhat.com)
  6. */
  7. #ifndef _NET_RXRPC_H
  8. #define _NET_RXRPC_H
  9. #include <linux/rxrpc.h>
  10. #include <linux/ktime.h>
  11. struct key;
  12. struct sock;
  13. struct socket;
  14. struct rxrpc_call;
  15. struct rxrpc_peer;
  16. struct krb5_buffer;
  17. enum rxrpc_abort_reason;
  18. enum rxrpc_interruptibility {
  19. RXRPC_INTERRUPTIBLE, /* Call is interruptible */
  20. RXRPC_PREINTERRUPTIBLE, /* Call can be cancelled whilst waiting for a slot */
  21. RXRPC_UNINTERRUPTIBLE, /* Call should not be interruptible at all */
  22. };
  23. enum rxrpc_oob_type {
  24. RXRPC_OOB_CHALLENGE, /* Security challenge for a connection */
  25. };
  26. /*
  27. * Debug ID counter for tracing.
  28. */
  29. extern atomic_t rxrpc_debug_id;
  30. /*
  31. * Operations table for rxrpc to call out to a kernel application (e.g. kAFS).
  32. */
  33. struct rxrpc_kernel_ops {
  34. void (*notify_new_call)(struct sock *sk, struct rxrpc_call *call,
  35. unsigned long user_call_ID);
  36. void (*discard_new_call)(struct rxrpc_call *call, unsigned long user_call_ID);
  37. void (*user_attach_call)(struct rxrpc_call *call, unsigned long user_call_ID);
  38. void (*notify_oob)(struct sock *sk, struct sk_buff *oob);
  39. };
  40. typedef void (*rxrpc_notify_rx_t)(struct sock *, struct rxrpc_call *,
  41. unsigned long);
  42. typedef void (*rxrpc_notify_end_tx_t)(struct sock *, struct rxrpc_call *,
  43. unsigned long);
  44. void rxrpc_kernel_set_notifications(struct socket *sock,
  45. const struct rxrpc_kernel_ops *app_ops);
  46. struct rxrpc_call *rxrpc_kernel_begin_call(struct socket *sock,
  47. struct rxrpc_peer *peer,
  48. struct key *key,
  49. unsigned long user_call_ID,
  50. s64 tx_total_len,
  51. u32 hard_timeout,
  52. gfp_t gfp,
  53. rxrpc_notify_rx_t notify_rx,
  54. u16 service_id,
  55. bool upgrade,
  56. enum rxrpc_interruptibility interruptibility,
  57. unsigned int debug_id);
  58. int rxrpc_kernel_send_data(struct socket *, struct rxrpc_call *,
  59. struct msghdr *, size_t,
  60. rxrpc_notify_end_tx_t);
  61. int rxrpc_kernel_recv_data(struct socket *, struct rxrpc_call *,
  62. struct iov_iter *, size_t *, bool, u32 *, u16 *);
  63. bool rxrpc_kernel_abort_call(struct socket *, struct rxrpc_call *,
  64. u32, int, enum rxrpc_abort_reason);
  65. void rxrpc_kernel_shutdown_call(struct socket *sock, struct rxrpc_call *call);
  66. void rxrpc_kernel_put_call(struct socket *sock, struct rxrpc_call *call);
  67. struct rxrpc_peer *rxrpc_kernel_lookup_peer(struct socket *sock,
  68. struct sockaddr_rxrpc *srx, gfp_t gfp);
  69. void rxrpc_kernel_put_peer(struct rxrpc_peer *peer);
  70. struct rxrpc_peer *rxrpc_kernel_get_peer(struct rxrpc_peer *peer);
  71. struct rxrpc_peer *rxrpc_kernel_get_call_peer(struct socket *sock, struct rxrpc_call *call);
  72. const struct sockaddr_rxrpc *rxrpc_kernel_remote_srx(const struct rxrpc_peer *peer);
  73. const struct sockaddr *rxrpc_kernel_remote_addr(const struct rxrpc_peer *peer);
  74. unsigned long rxrpc_kernel_set_peer_data(struct rxrpc_peer *peer, unsigned long app_data);
  75. unsigned long rxrpc_kernel_get_peer_data(const struct rxrpc_peer *peer);
  76. unsigned int rxrpc_kernel_get_srtt(const struct rxrpc_peer *);
  77. int rxrpc_kernel_charge_accept(struct socket *sock, rxrpc_notify_rx_t notify_rx,
  78. unsigned long user_call_ID, gfp_t gfp,
  79. unsigned int debug_id);
  80. void rxrpc_kernel_set_tx_length(struct socket *, struct rxrpc_call *, s64);
  81. bool rxrpc_kernel_check_life(const struct socket *, const struct rxrpc_call *);
  82. int rxrpc_sock_set_min_security_level(struct sock *sk, unsigned int val);
  83. int rxrpc_sock_set_security_keyring(struct sock *, struct key *);
  84. int rxrpc_sock_set_manage_response(struct sock *sk, bool set);
  85. enum rxrpc_oob_type rxrpc_kernel_query_oob(struct sk_buff *oob,
  86. struct rxrpc_peer **_peer,
  87. unsigned long *_peer_appdata);
  88. struct sk_buff *rxrpc_kernel_dequeue_oob(struct socket *sock,
  89. enum rxrpc_oob_type *_type);
  90. void rxrpc_kernel_free_oob(struct sk_buff *oob);
  91. void rxrpc_kernel_query_challenge(struct sk_buff *challenge,
  92. struct rxrpc_peer **_peer,
  93. unsigned long *_peer_appdata,
  94. u16 *_service_id, u8 *_security_index);
  95. int rxrpc_kernel_reject_challenge(struct sk_buff *challenge, u32 abort_code,
  96. int error, enum rxrpc_abort_reason why);
  97. int rxkad_kernel_respond_to_challenge(struct sk_buff *challenge);
  98. u32 rxgk_kernel_query_challenge(struct sk_buff *challenge);
  99. int rxgk_kernel_respond_to_challenge(struct sk_buff *challenge,
  100. struct krb5_buffer *appdata);
  101. u8 rxrpc_kernel_query_call_security(struct rxrpc_call *call,
  102. u16 *_service_id, u32 *_enctype);
  103. #endif /* _NET_RXRPC_H */