1  /*
2   * Copyright (c) 2017 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  #ifndef __WMA_FIPS_API_H
20  #define __WMA_FIPS_API_H
21  
22  #include "wma_api.h"
23  #include "wmi_unified_api.h"
24  #include "wma_fips_public_structs.h"
25  
26  #ifdef WLAN_FEATURE_FIPS
27  /**
28   * wma_fips_request() - Perform a FIPS certification operation
29   * @handle: WMA handle of the object being certified
30   * @param: The FIPS certification parameters
31   * @callback: Callback function to invoke with the results
32   * @context: Opaque context to pass back to caller in the callback
33   *
34   * Return: QDF_STATUS_SUCCESS if the request is successfully sent
35   * to firmware for processing, otherwise an error status.
36   */
37  QDF_STATUS wma_fips_request(WMA_HANDLE handle,
38  			    struct fips_params *param,
39  			    wma_fips_cb callback,
40  			    void *context);
41  
42  /**
43   * wma_fips_register_event_handlers() - Register FIPS event handlers
44   * @handle: WMA handle of the object being initialized
45   *
46   * This function registers all WMI event handlers required by the FIPS
47   * feature.
48   *
49   * Return: QDF_STATUS_SUCCESS upon success, otherwise an error
50   */
51  QDF_STATUS wma_fips_register_event_handlers(WMA_HANDLE handle);
52  
53  #else /* WLAN_FEATURE_FIPS */
54  
55  static inline
wma_fips_request(WMA_HANDLE handle,const struct fips_params * param,wma_fips_cb callback,void * context)56  QDF_STATUS wma_fips_request(WMA_HANDLE handle,
57  			    const struct fips_params *param,
58  			    wma_fips_cb callback,
59  			    void *context)
60  {
61  	return QDF_STATUS_E_NOSUPPORT;
62  }
63  
64  static inline
wma_fips_register_event_handlers(WMA_HANDLE wma_handle)65  QDF_STATUS wma_fips_register_event_handlers(WMA_HANDLE wma_handle)
66  {
67  	return QDF_STATUS_SUCCESS;
68  }
69  
70  #endif /* WLAN_FEATURE_FIPS */
71  
72  #endif /* __WMA_FIPS_API_H */
73