qdf_status.h 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. /*
  2. * Copyright (c) 2014-2020 The Linux Foundation. All rights reserved.
  3. * Copyright (c) 2022-2023 Qualcomm Innovation Center, Inc. All rights reserved.
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for
  6. * any purpose with or without fee is hereby granted, provided that the
  7. * above copyright notice and this permission notice appear in all
  8. * copies.
  9. *
  10. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  11. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  12. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  13. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  14. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  15. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  16. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  17. * PERFORMANCE OF THIS SOFTWARE.
  18. */
  19. /**
  20. * DOC: qdf_status
  21. * QCA driver framework (QDF) status codes
  22. * Basic status codes/definitions used by QDF
  23. */
  24. #ifndef __QDF_STATUS_H
  25. #define __QDF_STATUS_H
  26. /**
  27. * typedef QDF_STATUS - QDF error codes
  28. * @QDF_STATUS_SUCCESS: success
  29. * @QDF_STATUS_E_RESOURCES: system resource(other than memory) not available
  30. * @QDF_STATUS_E_NOMEM: not enough memory
  31. * @QDF_STATUS_E_AGAIN: try again
  32. * @QDF_STATUS_E_INVAL: invalid request
  33. * @QDF_STATUS_E_FAULT: system fault
  34. * @QDF_STATUS_E_ALREADY: another request already in progress
  35. * @QDF_STATUS_E_BADMSG: bad message
  36. * @QDF_STATUS_E_BUSY: device or resource busy
  37. * @QDF_STATUS_E_CANCELED: request cancelled
  38. * @QDF_STATUS_E_ABORTED: request aborted
  39. * @QDF_STATUS_E_NOSUPPORT: request not supported
  40. * @QDF_STATUS_E_PERM: operation not permitted
  41. * @QDF_STATUS_E_EMPTY: empty condition
  42. * @QDF_STATUS_E_EXISTS: existence failure
  43. * @QDF_STATUS_E_TIMEOUT: operation timeout
  44. * @QDF_STATUS_E_FAILURE: unknown reason do not use unless nothing else applies
  45. * @QDF_STATUS_E_NOENT: No such file or directory
  46. * @QDF_STATUS_E_E2BIG: Arg list too long
  47. * @QDF_STATUS_E_NOSPC: no space left on device
  48. * @QDF_STATUS_E_ADDRNOTAVAIL: Cannot assign requested address
  49. * @QDF_STATUS_E_ENXIO: No such device or address
  50. * @QDF_STATUS_E_NETDOWN: network is down
  51. * @QDF_STATUS_E_IO: I/O Error
  52. * @QDF_STATUS_E_PENDING: pending status
  53. * @QDF_STATUS_E_NETRESET: Network dropped connection because of reset
  54. * @QDF_STATUS_E_SIG: Exit due to received SIGINT
  55. * @QDF_STATUS_E_PROTO: protocol error
  56. * @QDF_STATUS_NOT_INITIALIZED: resource not initialized
  57. * @QDF_STATUS_E_NULL_VALUE: request is null
  58. * @QDF_STATUS_HEARTBEAT_TMOUT: heartbeat timeout error
  59. * @QDF_STATUS_NTH_BEACON_DELIVERY: Nth beacon delivery
  60. * @QDF_STATUS_CSR_WRONG_STATE: csr in wrong state
  61. * @QDF_STATUS_FT_PREAUTH_KEY_SUCCESS: ft preauth key success
  62. * @QDF_STATUS_FT_PREAUTH_KEY_FAILED: ft preauth key failed
  63. * @QDF_STATUS_CMD_NOT_QUEUED: command not queued
  64. * @QDF_STATUS_FW_MSG_TIMEDOUT: target message timeout
  65. * @QDF_STATUS_E_USB_ERROR: USB transaction error
  66. * @QDF_STATUS_MAXCOMP_FAIL: Component id is more than MAX UMAC components
  67. * @QDF_STATUS_COMP_DISABLED: UMAC Component is disabled
  68. * @QDF_STATUS_COMP_ASYNC: UMAC component runs in asynchronous communication
  69. * @QDF_STATUS_CRYPTO_PN_ERROR: PN ERROR in received frame
  70. * @QDF_STATUS_CRYPTO_MIC_FAILURE: MIC failure in received frame
  71. * @QDF_STATUS_CRYPTO_ENCRYPT_FAILED: encryption failed
  72. * @QDF_STATUS_CRYPTO_DECRYPT_FAILED: decryption failed
  73. * @QDF_STATUS_E_RANGE: result/parameter/operation was out of range
  74. * @QDF_STATUS_E_GRO_DROP: return code for GRO drop
  75. * @QDF_STATUS_E_RESTART: return error code for wait_event_interruptible
  76. * @QDF_STATUS_FILT_REQ_ERROR: return error code cee filter rule request
  77. * @QDF_STATUS_TDLS_MLO_SYNC: tdls mlo sync
  78. * @QDF_STATUS_CRYPTO_INVALID_KEYLEN: return code for invalid key length
  79. * @QDF_STATUS_CRYPTO_INVALID_KEYID: return code for invalid key index
  80. * @QDF_STATUS_CRYPTO_INVALID_CIPHERTYPE: return code for invalid cipher type
  81. * @QDF_STATUS_INVALID_ASSOCID: return code for invalid assoc id
  82. * @QDF_STATUS_MAX_VHT_STREAMS: Max VHT streams
  83. * @QDF_STATUS_NO_OVERLAP_LEGACY_RATES: no overlap legacy rate with assoc-req
  84. * @QDF_STATUS_MAX: not a real value just a place holder for max
  85. */
  86. typedef enum {
  87. QDF_STATUS_SUCCESS,
  88. QDF_STATUS_E_RESOURCES,
  89. QDF_STATUS_E_NOMEM,
  90. QDF_STATUS_E_AGAIN,
  91. QDF_STATUS_E_INVAL,
  92. QDF_STATUS_E_FAULT,
  93. QDF_STATUS_E_ALREADY,
  94. QDF_STATUS_E_BADMSG,
  95. QDF_STATUS_E_BUSY,
  96. QDF_STATUS_E_CANCELED,
  97. QDF_STATUS_E_ABORTED,
  98. QDF_STATUS_E_NOSUPPORT,
  99. QDF_STATUS_E_PERM,
  100. QDF_STATUS_E_EMPTY,
  101. QDF_STATUS_E_EXISTS,
  102. QDF_STATUS_E_TIMEOUT,
  103. QDF_STATUS_E_FAILURE,
  104. QDF_STATUS_E_NOENT,
  105. QDF_STATUS_E_E2BIG,
  106. QDF_STATUS_E_NOSPC,
  107. QDF_STATUS_E_ADDRNOTAVAIL,
  108. QDF_STATUS_E_ENXIO,
  109. QDF_STATUS_E_NETDOWN,
  110. QDF_STATUS_E_IO,
  111. QDF_STATUS_E_PENDING,
  112. QDF_STATUS_E_NETRESET,
  113. QDF_STATUS_E_SIG,
  114. QDF_STATUS_E_PROTO,
  115. QDF_STATUS_NOT_INITIALIZED,
  116. QDF_STATUS_E_NULL_VALUE,
  117. QDF_STATUS_HEARTBEAT_TMOUT,
  118. QDF_STATUS_NTH_BEACON_DELIVERY,
  119. QDF_STATUS_CSR_WRONG_STATE,
  120. QDF_STATUS_FT_PREAUTH_KEY_SUCCESS,
  121. QDF_STATUS_FT_PREAUTH_KEY_FAILED,
  122. QDF_STATUS_CMD_NOT_QUEUED,
  123. QDF_STATUS_FW_MSG_TIMEDOUT,
  124. QDF_STATUS_E_USB_ERROR,
  125. QDF_STATUS_MAXCOMP_FAIL,
  126. QDF_STATUS_COMP_DISABLED,
  127. QDF_STATUS_COMP_ASYNC,
  128. QDF_STATUS_CRYPTO_PN_ERROR,
  129. QDF_STATUS_CRYPTO_MIC_FAILURE,
  130. QDF_STATUS_CRYPTO_ENCRYPT_FAILED,
  131. QDF_STATUS_CRYPTO_DECRYPT_FAILED,
  132. QDF_STATUS_E_DEFRAG_ERROR,
  133. QDF_STATUS_E_RANGE,
  134. QDF_STATUS_E_GRO_DROP,
  135. QDF_STATUS_E_RESTART,
  136. QDF_STATUS_FILT_REQ_ERROR,
  137. QDF_STATUS_TDLS_MLO_SYNC,
  138. QDF_STATUS_CRYPTO_INVALID_KEYLEN,
  139. QDF_STATUS_CRYPTO_INVALID_KEYID,
  140. QDF_STATUS_CRYPTO_INVALID_CIPHERTYPE,
  141. QDF_STATUS_INVALID_ASSOCID,
  142. QDF_STATUS_MAX_VHT_STREAMS,
  143. QDF_STATUS_NO_OVERLAP_LEGACY_RATES,
  144. QDF_STATUS_MAX
  145. } QDF_STATUS;
  146. #define QDF_IS_STATUS_SUCCESS(status) (QDF_STATUS_SUCCESS == (status))
  147. #define QDF_IS_STATUS_ERROR(status) (QDF_STATUS_SUCCESS != (status))
  148. /**
  149. * qdf_status_to_os_return() - map a QDF_STATUS into an OS specific return code
  150. * @status: QDF_STATUS to map
  151. *
  152. * Return: an OS specific error code
  153. */
  154. int qdf_status_to_os_return(QDF_STATUS status);
  155. /**
  156. * qdf_status_from_os_return() - map an OS specific return code to a QDF_STATUS
  157. * @rc: the input return code to map
  158. *
  159. * Return: QDF_STATUS
  160. */
  161. QDF_STATUS qdf_status_from_os_return(int rc);
  162. #endif /* __QDF_STATUS_H */