tls_proc.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. // SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
  2. /* Copyright (C) 2019 Netronome Systems, Inc. */
  3. #include <linux/proc_fs.h>
  4. #include <linux/seq_file.h>
  5. #include <net/snmp.h>
  6. #include <net/tls.h>
  7. #include "tls.h"
  8. #ifdef CONFIG_PROC_FS
  9. static const struct snmp_mib tls_mib_list[] = {
  10. SNMP_MIB_ITEM("TlsCurrTxSw", LINUX_MIB_TLSCURRTXSW),
  11. SNMP_MIB_ITEM("TlsCurrRxSw", LINUX_MIB_TLSCURRRXSW),
  12. SNMP_MIB_ITEM("TlsCurrTxDevice", LINUX_MIB_TLSCURRTXDEVICE),
  13. SNMP_MIB_ITEM("TlsCurrRxDevice", LINUX_MIB_TLSCURRRXDEVICE),
  14. SNMP_MIB_ITEM("TlsTxSw", LINUX_MIB_TLSTXSW),
  15. SNMP_MIB_ITEM("TlsRxSw", LINUX_MIB_TLSRXSW),
  16. SNMP_MIB_ITEM("TlsTxDevice", LINUX_MIB_TLSTXDEVICE),
  17. SNMP_MIB_ITEM("TlsRxDevice", LINUX_MIB_TLSRXDEVICE),
  18. SNMP_MIB_ITEM("TlsDecryptError", LINUX_MIB_TLSDECRYPTERROR),
  19. SNMP_MIB_ITEM("TlsRxDeviceResync", LINUX_MIB_TLSRXDEVICERESYNC),
  20. SNMP_MIB_ITEM("TlsDecryptRetry", LINUX_MIB_TLSDECRYPTRETRY),
  21. SNMP_MIB_ITEM("TlsRxNoPadViolation", LINUX_MIB_TLSRXNOPADVIOL),
  22. SNMP_MIB_SENTINEL
  23. };
  24. static int tls_statistics_seq_show(struct seq_file *seq, void *v)
  25. {
  26. unsigned long buf[LINUX_MIB_TLSMAX] = {};
  27. struct net *net = seq->private;
  28. int i;
  29. snmp_get_cpu_field_batch(buf, tls_mib_list, net->mib.tls_statistics);
  30. for (i = 0; tls_mib_list[i].name; i++)
  31. seq_printf(seq, "%-32s\t%lu\n", tls_mib_list[i].name, buf[i]);
  32. return 0;
  33. }
  34. #endif
  35. int __net_init tls_proc_init(struct net *net)
  36. {
  37. #ifdef CONFIG_PROC_FS
  38. if (!proc_create_net_single("tls_stat", 0444, net->proc_net,
  39. tls_statistics_seq_show, NULL))
  40. return -ENOMEM;
  41. #endif /* CONFIG_PROC_FS */
  42. return 0;
  43. }
  44. void __net_exit tls_proc_fini(struct net *net)
  45. {
  46. remove_proc_entry("tls_stat", net->proc_net);
  47. }