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