wlan_disa_public_struct.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /*
  2. * Copyright (c) 2018 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. /**
  19. * DOC: Declare various struct, macros which shall be used in the DISA
  20. * component.
  21. *
  22. * Note: This file shall not contain public API's prototype/declarations.
  23. *
  24. */
  25. #ifndef _WLAN_DISA_PUBLIC_STRUCT_H_
  26. #define _WLAN_DISA_PUBLIC_STRUCT_H_
  27. #include <qdf_types.h>
  28. #define MAC_MAX_KEY_LENGTH 32
  29. #define MAC_PN_LENGTH 8
  30. #define MAX_MAC_HEADER_LEN 32
  31. #define MIN_MAC_HEADER_LEN 24
  32. /**
  33. * struct disa_encrypt_decrypt_req_params - disa encrypt request
  34. * @vdev_id: virtual device id
  35. * @key_flag: This indicates firmware to encrypt/decrypt payload
  36. * see ENCRYPT_DECRYPT_FLAG
  37. * @key_idx: Index used in storing key
  38. * @key_cipher: cipher used for encryption/decryption
  39. * Eg: see WMI_CIPHER_AES_CCM for CCMP
  40. * @key_len: length of key data
  41. * @key_txmic_len: length of Tx MIC
  42. * @key_rxmic_len: length of Rx MIC
  43. * @key_data: Key
  44. * @pn: packet number
  45. * @mac_header: MAC header
  46. * @data_len: length of data
  47. * @data: pointer to payload
  48. */
  49. struct disa_encrypt_decrypt_req_params {
  50. uint32_t vdev_id;
  51. uint8_t key_flag;
  52. uint32_t key_idx;
  53. uint32_t key_cipher;
  54. uint32_t key_len;
  55. uint32_t key_txmic_len;
  56. uint32_t key_rxmic_len;
  57. uint8_t key_data[MAC_MAX_KEY_LENGTH];
  58. uint8_t pn[MAC_PN_LENGTH];
  59. uint8_t mac_header[MAX_MAC_HEADER_LEN];
  60. uint32_t data_len;
  61. uint8_t *data;
  62. };
  63. /**
  64. * struct disa_encrypt_decrypt_resp_params - disa encrypt response
  65. * @vdev_id: vdev id
  66. * @status: status
  67. * @data_length: data length
  68. * @data: data pointer
  69. */
  70. struct disa_encrypt_decrypt_resp_params {
  71. uint32_t vdev_id;
  72. int32_t status;
  73. uint32_t data_len;
  74. uint8_t *data;
  75. };
  76. typedef void (*encrypt_decrypt_resp_callback)(void *cookie,
  77. struct disa_encrypt_decrypt_resp_params *resp) ;
  78. #endif /* end of _WLAN_DISA_PUBLIC_STRUCT_H_ */