You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					1039 lines
				
				46 KiB
			
		
		
			
		
	
	
					1039 lines
				
				46 KiB
			| 
											3 days ago
										 | /*-----------------------------------------------------------------------------
 | ||
|  |    Copyright (c) 2012-2014,2016,2017,2019-2021 QUALCOMM Technologies, Incorporated.
 | ||
|  |    All Rights Reserved.
 | ||
|  |    Redistribution and use in source and binary forms, with or without
 | ||
|  |    modification, are permitted provided that the following conditions are met:
 | ||
|  | 
 | ||
|  |    1. Redistributions of source code must retain the above copyright notice,
 | ||
|  |    this list of conditions and the following disclaimer.
 | ||
|  | 
 | ||
|  |    2. Redistributions in binary form must reproduce the above copyright notice,
 | ||
|  |    this list of conditions and the following disclaimer in the documentation
 | ||
|  |    and/or other materials provided with the distribution.
 | ||
|  | 
 | ||
|  |    3. Neither the name of the copyright holder nor the names of its contributors
 | ||
|  |    may be used to endorse or promote products derived from this software without
 | ||
|  |    specific prior written permission.
 | ||
|  | 
 | ||
|  |    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 | ||
|  |    AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 | ||
|  |    IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 | ||
|  |    ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
 | ||
|  |    LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 | ||
|  |    CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 | ||
|  |    SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 | ||
|  |    INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 | ||
|  |    CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 | ||
|  |    ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 | ||
|  |    POSSIBILITY OF SUCH DAMAGE.
 | ||
|  | -----------------------------------------------------------------------------*/
 | ||
|  | #ifndef REMOTE_DEFAULT_H
 | ||
|  | #define REMOTE_DEFAULT_H
 | ||
|  | 
 | ||
|  | #include <stdint.h>
 | ||
|  | #include <sys/types.h>
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" {
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  *  @file remote.h
 | ||
|  |  *  @brief Header file with APIs to interface with FastRPC.
 | ||
|  |  */
 | ||
|  | 
 | ||
|  | typedef uint32_t remote_handle;        /**< Handle used by non-domain modules */
 | ||
|  | typedef uint64_t remote_handle64;      /**< Handle used by multi-domain modules */
 | ||
|  | typedef uint64_t fastrpc_async_jobid;  /**< Job ID filled in the remote_handle_invoke_async() call*/
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_buf
 | ||
|  |  * @brief remote buffer for arguments.
 | ||
|  |  */
 | ||
|  | typedef struct {
 | ||
|  |    void *pv;    /**< Buffer pointer for input/output arguments */
 | ||
|  |    size_t nLen; /**< Buffer size for input/output arguments */
 | ||
|  | } remote_buf;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_dma_handle
 | ||
|  |  * @brief remote handle  structure for passing fd.
 | ||
|  |  */
 | ||
|  | typedef struct {
 | ||
|  |    int32_t fd;       /**< File Desecripter for buffer */
 | ||
|  |    uint32_t offset;  /**< Buffer offset */
 | ||
|  | } remote_dma_handle;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @union remote_arg
 | ||
|  |  * @brief union of different types of arguments that are passed to the remote invocation call
 | ||
|  |  */
 | ||
|  | typedef union {
 | ||
|  |    remote_buf     buf;    /**< Buffer holds pointer and size for given argument */
 | ||
|  |    remote_handle    h;    /**< Handle for non-domains modules */
 | ||
|  |    remote_handle64 h64;   /**< Handle for multi-omains modules */
 | ||
|  |    remote_dma_handle dma; /**< DMA Handle that holds buffer fd and offset */
 | ||
|  | } remote_arg;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @enum fastrpc_async_notify_type
 | ||
|  |  * @brief Types of Asynchronous complete notifications
 | ||
|  |  */
 | ||
|  | enum fastrpc_async_notify_type {
 | ||
|  |    FASTRPC_ASYNC_NO_SYNC = 0,   /**< synchronous call */
 | ||
|  |    FASTRPC_ASYNC_CALLBACK,      /**< asynchronous call with callback response */
 | ||
|  |    FASTRPC_ASYNC_POLL,          /**< asynchronous call with polling response */
 | ||
|  |    FASTRPC_ASYNC_TYPE_MAX,      /**< reserved */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct fastrpc_async_callback
 | ||
|  |  * @brief call back function and context for asynchronous complete notification
 | ||
|  |  */
 | ||
|  | typedef struct fastrpc_async_callback {
 | ||
|  |    void (*fn)(fastrpc_async_jobid jobid, void* context, int result); /**< call back function */
 | ||
|  |    void *context;                                                    /**< unique context filled by user */
 | ||
|  | }fastrpc_async_callback_t;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct fastrpc_async_descriptor
 | ||
|  |  * @brief  descriptor for defining the complete notification mechanism for given remote invocation call.
 | ||
|  |  */
 | ||
|  | 
 | ||
|  | typedef struct fastrpc_async_descriptor {
 | ||
|  |    enum fastrpc_async_notify_type type; /**< asynchronous notification type */
 | ||
|  |    fastrpc_async_jobid jobid;           /**< Job ID returned in async remote invocation call */
 | ||
|  |    union {
 | ||
|  |       fastrpc_async_callback_t cb;      /**< call back function filled by user */
 | ||
|  |    };
 | ||
|  | }fastrpc_async_descriptor_t;
 | ||
|  | 
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Retrieves method attribute from the scalars parameter
 | ||
|  |  */
 | ||
|  | #define REMOTE_SCALARS_METHOD_ATTR(dwScalars)   (((dwScalars) >> 29) & 0x7)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Retrieves method index from the scalars parameter
 | ||
|  |  */
 | ||
|  | #define REMOTE_SCALARS_METHOD(dwScalars)        (((dwScalars) >> 24) & 0x1f)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Retrieves number of input buffers from the scalars parameter
 | ||
|  |  */
 | ||
|  | #define REMOTE_SCALARS_INBUFS(dwScalars)        (((dwScalars) >> 16) & 0x0ff)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Retrieves number of output buffers from the scalars parameter
 | ||
|  |  */
 | ||
|  | #define REMOTE_SCALARS_OUTBUFS(dwScalars)       (((dwScalars) >> 8) & 0x0ff)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Retrieves number of input handles from the scalars parameter
 | ||
|  |  */
 | ||
|  | #define REMOTE_SCALARS_INHANDLES(dwScalars)     (((dwScalars) >> 4) & 0x0f)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Retrieves number of output handles from the scalars parameter
 | ||
|  |  */
 | ||
|  | #define REMOTE_SCALARS_OUTHANDLES(dwScalars)    ((dwScalars) & 0x0f)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal scalars parameter construction for given nAttr, nMethod, nIn, nOut, noIn and noOut
 | ||
|  |  */
 | ||
|  | #define REMOTE_SCALARS_MAKEX(nAttr,nMethod,nIn,nOut,noIn,noOut) \
 | ||
|  |           ((((uint32_t)   (nAttr) &  0x7) << 29) | \
 | ||
|  |            (((uint32_t) (nMethod) & 0x1f) << 24) | \
 | ||
|  |            (((uint32_t)     (nIn) & 0xff) << 16) | \
 | ||
|  |            (((uint32_t)    (nOut) & 0xff) <<  8) | \
 | ||
|  |            (((uint32_t)    (noIn) & 0x0f) <<  4) | \
 | ||
|  |             ((uint32_t)   (noOut) & 0x0f))
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal scalars parameter construction for given nAttr, nMethod, nIn, nOut
 | ||
|  |  */
 | ||
|  | #define REMOTE_SCALARS_MAKE(nMethod,nIn,nOut)  REMOTE_SCALARS_MAKEX(0,nMethod,nIn,nOut,0,0)
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal total number of different arguments for given scalars parameter
 | ||
|  |  */
 | ||
|  | #define REMOTE_SCALARS_LENGTH(sc) (REMOTE_SCALARS_INBUFS(sc) +\
 | ||
|  |                                    REMOTE_SCALARS_OUTBUFS(sc) +\
 | ||
|  |                                    REMOTE_SCALARS_INHANDLES(sc) +\
 | ||
|  |                                    REMOTE_SCALARS_OUTHANDLES(sc))
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal macro for function definition
 | ||
|  |  */
 | ||
|  | #ifndef __QAIC_REMOTE
 | ||
|  | 
 | ||
|  | #define __QAIC_REMOTE(ff) ff
 | ||
|  | #endif //__QAIC_REMOTE
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal macro for function declaration
 | ||
|  |  */
 | ||
|  | #ifndef __QAIC_REMOTE_EXPORT
 | ||
|  | #ifdef _WIN32
 | ||
|  | #define __QAIC_REMOTE_EXPORT __declspec(dllexport)
 | ||
|  | #else //_WIN32
 | ||
|  | #define __QAIC_REMOTE_EXPORT
 | ||
|  | #endif //_WIN32
 | ||
|  | #endif //__QAIC_REMOTE_EXPORT
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal macro for function declaration
 | ||
|  |  */
 | ||
|  | #ifndef __QAIC_REMOTE_ATTRIBUTE
 | ||
|  | #define __QAIC_REMOTE_ATTRIBUTE
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Number of Remote Domains
 | ||
|  |  */
 | ||
|  | #define NUM_DOMAINS 4
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Number of sessions for given process
 | ||
|  |  */
 | ||
|  | #define NUM_SESSIONS 2
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal Mask to retrieve domain
 | ||
|  |  */
 | ||
|  | #define DOMAIN_ID_MASK 3
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Default remote process domain
 | ||
|  |  */
 | ||
|  | #ifndef DEFAULT_DOMAIN_ID
 | ||
|  | #define DEFAULT_DOMAIN_ID 0
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal remote process domain ID definition for ADSP
 | ||
|  |  */
 | ||
|  | #define ADSP_DOMAIN_ID    0
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal remote process domain ID definition MDSP
 | ||
|  |  */
 | ||
|  | #define MDSP_DOMAIN_ID    1
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal remote process domain ID definition for SDSP
 | ||
|  |  */
 | ||
|  | #define SDSP_DOMAIN_ID    2
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal remote process domain ID definition for CDSP
 | ||
|  |  */
 | ||
|  | #define CDSP_DOMAIN_ID    3
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal ADSP remote process definition to check remote process domain from uri
 | ||
|  |  */
 | ||
|  | #define ADSP_DOMAIN "&_dom=adsp"
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal MDSP remote process definition to check remote process domain from uri
 | ||
|  |  */
 | ||
|  | #define MDSP_DOMAIN "&_dom=mdsp"
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal SDSP remote process definition to check remote process domain from uri
 | ||
|  |  */
 | ||
|  | #define SDSP_DOMAIN "&_dom=sdsp"
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal CDSP remote process definition to check remote process domain from uri
 | ||
|  |  */
 | ||
|  | #define CDSP_DOMAIN "&_dom=cdsp"
 | ||
|  | 
 | ||
|  | /**Process Types
 | ||
|  |  * Return values for FASTRPC_REMOTE_PROCESS_TYPE in enum session_control_req_id for remote_handle_control
 | ||
|  |  * Return values denote the type of process on remote subsystem
 | ||
|  |  */
 | ||
|  | enum fastrpc_process_type {
 | ||
|  |   PROCESS_TYPE_SIGNED   = 0,
 | ||
|  |   PROCESS_TYPE_UNSIGNED = 1,
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Loads the shared object in remote process and returns the handle to it
 | ||
|  |  * This API used for non-domains use case
 | ||
|  |  *
 | ||
|  |  * @param[in] name pointer to name of the shared object
 | ||
|  |  * @param[out] ph pointer to handle
 | ||
|  |  *
 | ||
|  |  * @return 0 for success and non-zero for failure.\n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EBADPARM. Other than this error code,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  | */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle_open)(const char* name, remote_handle *ph) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Loads the shared object in remote process and returns the handle to it
 | ||
|  |  * This API used for domains use case
 | ||
|  |  *
 | ||
|  |  * @param[in] name pointer to name of the shared object
 | ||
|  |  * @param[out] ph pointer to handle
 | ||
|  |  *
 | ||
|  |  * @return 0 for success and non-zero for failure.\n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EBADPARM. Other than this error code,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  | */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle64_open)(const char* name, remote_handle64 *ph) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Makes remote call for given handle synchronously
 | ||
|  |  * This API used for non-domains use case
 | ||
|  |  *
 | ||
|  |  * @param[in]  h successful handle returned via #remote_handle_open()
 | ||
|  |  * @param[in]  pra pointer to union #remote_arg \n
 | ||
|  |  * A sequence of arguments in the following order inbufs, outbufs, inhandles, outhandles.
 | ||
|  |  * @param[in]  dwScalars integer packs Method ID, number of inputs, outputs, inhandles and outhandles
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error code due to incorrect input arguments are AEE_EINVHANDLE, AEE_EBADPARM. Other than these error codes,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle_invoke)(remote_handle h, uint32_t dwScalars, remote_arg *pra) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Makes remote call for given handle synchronously
 | ||
|  |  * This API used for domains use case
 | ||
|  |  *
 | ||
|  |  * @param[in]  h successful handle returned via #remote_handle_open()
 | ||
|  |  * @param[in]  pra pointer to union #remote_arg \n
 | ||
|  |  * A sequence of arguments in the following order inbufs, outbufs, inhandles, outhandles.
 | ||
|  |  * @param[in]  dwScalars integer packs Method ID, number of inputs, outputs, inhandles and outhandles
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error code due to incorrect input arguments are AEE_EINVHANDLE, AEE_EBADPARM. Other than these error codes,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle64_invoke)(remote_handle64 h, uint32_t dwScalars, remote_arg *pra) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Makes remote call for given handle asynchronously
 | ||
|  |  * This API used for non-domains use case
 | ||
|  |  *
 | ||
|  |  * @param[in]  h successful handle returned via #remote_handle_open()
 | ||
|  |  * @param[in]  desc pointer to structure #fastrpc_async_descriptor_t
 | ||
|  |  * @param[in]  pra pointer to union #remote_arg \n
 | ||
|  |  * sequence of arguments in following order input buffers, output\n
 | ||
|  |  * buffers, in handles and out handles. The number of each type of argument\n
 | ||
|  |  * given in dwScalars below.
 | ||
|  |  * @param[in]  dwScalars \n
 | ||
|  |  * Sequence of the following integers related to invocation: The method ID\
 | ||
|  |  * the number of input buffers in pra, the number of out buffers in pra,
 | ||
|  |  * the number of in handles in pra and the number out handles in pra.
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error codes due to incorrect input arguments are AEE_EINVHANDLE, AEE_EBADPARM. Other than these error codes,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle_invoke_async)(remote_handle h, fastrpc_async_descriptor_t *desc, uint32_t dwScalars, remote_arg *pra) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Makes remote call for given handle asynchronously
 | ||
|  |  * This API used for domains use case
 | ||
|  |  *
 | ||
|  |  * @param[in]  h successful handle returned via #remote_handle_open()
 | ||
|  |  * @param[in]  desc pointer to structure #fastrpc_async_descriptor_t
 | ||
|  |  * @param[in]  pra pointer to union #remote_arg \n
 | ||
|  |  * sequence of arguments in following order input buffers, output\n
 | ||
|  |  * buffers, in handles and out handles. The number of each type of argument\n
 | ||
|  |  * given in dwScalars below.
 | ||
|  |  * @param[in]  dwScalars \n
 | ||
|  |  * Sequence of the following integers related to invocation: The method ID\
 | ||
|  |  * the number of input buffers in pra, the number of out buffers in pra,
 | ||
|  |  * the number of in handles in pra and the number out handles in pra.
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error codes due to incorrect input arguments are AEE_EINVHANDLE, AEE_EBADPARM. Other than these error codes,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle64_invoke_async)(remote_handle64 h, fastrpc_async_descriptor_t *desc, uint32_t dwScalars, remote_arg *pra) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Unloads the shared object for given handle
 | ||
|  |  * This API used for non-domains use case
 | ||
|  |  *
 | ||
|  |  * @param[in]  h successful handle returned via #remote_handle_open()
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EINVHANDLE. Other than this error code,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle_close)(remote_handle h) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Unloads the shared object for given handle
 | ||
|  |  * This API used for domains use case
 | ||
|  |  *
 | ||
|  |  * @param[in]  h successful handle returned via #remote_handle_open()
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EINVHANDLE. Other than this error code,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle64_close)(remote_handle64 h) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @enum handle_control_req_id
 | ||
|  |  * @brief different types of requests that are passed to the remote handle control API
 | ||
|  |  */
 | ||
|  | enum handle_control_req_id {
 | ||
|  |     DSPRPC_CONTROL_LATENCY  =   1, /**< fastrpc latency control */
 | ||
|  |     DSPRPC_GET_DSP_INFO     =   2, /**< Query DSP capabilities */
 | ||
|  |     DSPRPC_CONTROL_WAKELOCK =   3, /**< Enable or disable wake lock  */
 | ||
|  |     DSPRPC_GET_DOMAIN       =   4, /**< getting the domain */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @enum remote_rpc_latency_flags
 | ||
|  |  * @brief Types of QOS allowed with request ID DSPRPC_CONTROL_LATENCY
 | ||
|  | 
 | ||
|  |  */
 | ||
|  | typedef enum remote_rpc_latency_flags {
 | ||
|  |    RPC_DISABLE_QOS = 0,   /**< Disable PM QOS. */
 | ||
|  |    RPC_PM_QOS = 1,        /**< Enable PM QOS */
 | ||
|  |    RPC_ADAPTIVE_QOS = 2,  /**< Enable Adaptive QOS */
 | ||
|  |    RPC_POLL_QOS = 3,      /**< Enable Poll QOS */
 | ||
|  | } remote_rpc_control_latency_t;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_control_latency
 | ||
|  |  * @brief Argument for setting latency with request ID DSPRPC_CONTROL_LATENCY\n
 | ||
|  |  * PM QoS control cpu low power modes based on RPC activity in 100 ms window. Recommended for latency sensitive use cases.\n
 | ||
|  |  * Adaptive QoS, DSP driver predicts completion time of a method and send CPU wake up signal to reduce wake up latency
 | ||
|  |  * Recommended for moderate latency sensitive use cases. It is more power efficient compared to pm_qos control.
 | ||
|  |  * Poll QoS, After sending invocation to DSP, CPU will enter polling mode instead of waiting for a glink response.
 | ||
|  |  * This will boost fastrpc performance by reducing the CPU wakeup and scheduling times.
 | ||
|  |  */
 | ||
|  | struct remote_rpc_control_latency {
 | ||
|  |    remote_rpc_control_latency_t enable;           /**< Enable type of QOS one of enum #remote_rpc_latency_flags*/
 | ||
|  |    uint32_t latency;          /**< Latency is the time between CPU application making the remote call and beginning of remote DSP method execution.
 | ||
|  |                                    When used with poll QoS, user needs to pass the expected execution time of method on DSP. CPU will poll for a DSP
 | ||
|  |                                    response for that specified duration after which it will timeout and fall back to waiting for a glink response.  */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @enum remote_dsp_attributes
 | ||
|  |  * @brief Different types of DSP capabilities queried via remote_handle_control
 | ||
|  |  */
 | ||
|  | enum remote_dsp_attributes {
 | ||
|  |    DOMAIN_SUPPORT              = 0,                               /**< Domains feature support*/
 | ||
|  |    UNSIGNED_PD_SUPPORT         = 1,                               /**< Unsigned PD feature support*/
 | ||
|  |    HVX_SUPPORT_64B             = 2,                               /**< Number of HVX 64B support*/
 | ||
|  |    HVX_SUPPORT_128B            = 3,                               /**< Number of HVX 128B support*/
 | ||
|  |    VTCM_PAGE                   = 4,                               /**< Max page size allocation possible in VTCM */
 | ||
|  |    VTCM_COUNT                  = 5,                               /**< Number of page_size blocks available */
 | ||
|  |    ARCH_VER                    = 6,                               /**< Hexagon processor architecture version */
 | ||
|  |    HMX_SUPPORT_DEPTH           = 7,                               /**< HMX Support Depth */
 | ||
|  |    HMX_SUPPORT_SPATIAL         = 8,                               /**< HMX Support Spatial */
 | ||
|  |    ASYNC_FASTRPC_SUPPORT       = 9,                               /**< Async FastRPC Support */
 | ||
|  |    STATUS_NOTIFICATION_SUPPORT = 10,                              /**< DSP User PD status notification Support */
 | ||
|  |    FASTRPC_MAX_DSP_ATTRIBUTES  = STATUS_NOTIFICATION_SUPPORT + 1, /**< Number of attributes supported */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_dsp_capability
 | ||
|  |  * @brief Argument to query DSP capability with request ID DSPRPC_GET_DSP_INFO
 | ||
|  |  */
 | ||
|  | typedef struct remote_dsp_capability {
 | ||
|  |    uint32_t domain;       /**<  Remote domain ID */
 | ||
|  |    uint32_t attribute_ID; /**<  One of the DSP capabilities from enum #remote_dsp_attributes */
 | ||
|  |    uint32_t capability;   /**<  Output is capability and possible values vary based on attribute_ID
 | ||
|  |    For DOMAIN_SUPPORT, output values are one, zero.
 | ||
|  |    For UNSIGNED_PD_SUPPORT, output values are one, zero
 | ||
|  |    For, HVX_SUPPORT_64B, output is number of HVX 64B supported
 | ||
|  |    For, HVX_SUPPORT_128B, output is number HVX 128B supported
 | ||
|  |    For VTCM_PAGE, output is Max page size allocation possible in VTCM
 | ||
|  |    For VTCM_COUNT, output is Number of page_size blocks available
 | ||
|  |    For ARCH_VER, output is Hexagon processor architecture version
 | ||
|  |    For HMX_SUPPORT, output is one or zero
 | ||
|  |    For ASYNC_FASTRPC_SUPPORT, output is one or zero*/
 | ||
|  | } fastrpc_capability;
 | ||
|  | 
 | ||
|  | /** Macro for backward compatbility. Clients can compile wakelock request code
 | ||
|  |  * in their app only when this is defined */
 | ||
|  | #define FASTRPC_WAKELOCK_CONTROL_SUPPORTED 1
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_control_wakelock
 | ||
|  |  * @brief Argument for enable/disable wake lock with request ID DSPRPC_CONTROL_WAKELOCK\n
 | ||
|  |  * CPU can go into suspend mode anytime. For clients who want to keep the CPU awake until they get a response for their
 | ||
|  |  * remote invocation call, recommended to use wake lock feature.
 | ||
|  | 
 | ||
|  |  */
 | ||
|  | struct remote_rpc_control_wakelock {
 | ||
|  |     uint32_t enable;    /**< enable control of wake lock */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_get_domain
 | ||
|  |  * @brief Argument to get domain from handle with request ID DSPRPC_GET_DOMAIN
 | ||
|  |  */
 | ||
|  | typedef struct remote_rpc_get_domain {
 | ||
|  |    int domain;         /**< Domain ID*/
 | ||
|  |  } remote_rpc_get_domain_t;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * remote_handle64_control API allows to enable features based on handle
 | ||
|  |  *
 | ||
|  |  * @param[in]  req  one of enum from #handle_control_req_id\n
 | ||
|  |  * Req ID #DSPRPC_CONTROL_LATENCY is used for enable PM QoS, adaptive QoS\n
 | ||
|  |  * Req ID #DSPRPC_GET_DSP_INFO is used for query types of features supported\n
 | ||
|  |  * Req ID #DSPRPC_CONTROL_WAKELOCK is used for enable/disable wake lock\n
 | ||
|  |  * Req ID #DSPRPC_GET_DOMAIN is used for getting the domain ID for given handle\n
 | ||
|  |  *
 | ||
|  |  * @param[in,out] data  void pointer to struct for input params\n
 | ||
|  |  * Inputs\n
 | ||
|  |  * struct #remote_rpc_control_latency is used for enable PM QoS, adaptive QoS \n
 | ||
|  |  * struct #remote_dsp_capability is used for query features supported or not. Listed in #remote_dsp_attributes \n
 | ||
|  |  * struct #remote_rpc_control_wakelock is used for enable/disable wake lock \n
 | ||
|  |  * struct #remote_rpc_get_domain is used for getting the domain for given handle \n
 | ||
|  |  * outputs\n
 | ||
|  |  * For req #DSPRPC_CONTROL_LATENCY, output is same as API return value \n
 | ||
|  |  * For req #DSPRPC_GET_DSP_INFO, output is capability argument from #remote_dsp_capability \n
 | ||
|  |  * For req #DSPRPC_CONTROL_WAKELOCK, output is  same as API return value \n
 | ||
|  |  * For req #DSPRPC_GET_DOMAIN, output is domain argument from #remote_rpc_get_domain \n
 | ||
|  |  *
 | ||
|  |  * @param[in] datalen Length of the struct defintion used for input params
 | ||
|  |  *
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error codes due to incorrect input arguments are AEE_EBADPARM, AEE_EUNSUPPORTED.
 | ||
|  |  * Other than these error codes, treated as returned from fastRPC framework issues.
 | ||
|  |  *
 | ||
|  |  * For example:
 | ||
|  |  * @code
 | ||
|  |  * struct remote_rpc_control_latency data;
 | ||
|  |  * data.enable = 1;
 | ||
|  |  * data.latency = 100;
 | ||
|  |  *
 | ||
|  |  * if (remote_handle64_control)
 | ||
|  |  *    remote_handle64_control(h, DSPRPC_CONTROL_LATENCY, (void*)&data, sizeof(data));
 | ||
|  |  * else
 | ||
|  |  *    printf("remote_handle64_control not available on this target");
 | ||
|  |  * @endcode
 | ||
|  | */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle_control)(uint32_t req, void* data, uint32_t datalen) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * remote_handle64_control API allows to enable features based on handle
 | ||
|  |  * This API used for domains use case
 | ||
|  |  *
 | ||
|  |  * @param[in] h successful handle returned via #remote_handle_open() \n
 | ||
|  |  * @param[in] req one of enum from #handle_control_req_id \n
 | ||
|  |  * Req ID #DSPRPC_CONTROL_LATENCY is used for enable PM QoS, adaptive QoS\n
 | ||
|  |  * Req ID #DSPRPC_GET_DSP_INFO is used for query types of features supported\n
 | ||
|  |  * Req ID #DSPRPC_CONTROL_WAKELOCK is used for enable/disable wake lock\n
 | ||
|  |  * Req ID #DSPRPC_GET_DOMAIN is used for getting the domain ID for given handle\n
 | ||
|  |  *
 | ||
|  |  * @param[in,out] data  void pointer to struct for input params\n
 | ||
|  |  * Inputs\n
 | ||
|  |  * struct #remote_rpc_control_latency is used for enable PM QoS, adaptive QoS \n
 | ||
|  |  * struct #remote_dsp_capability is used for query features supported or not. Listed in #remote_dsp_attributes \n
 | ||
|  |  * struct #remote_rpc_control_wakelock is used for enable/disable wake lock \n
 | ||
|  |  * struct #remote_rpc_get_domain is used for getting the domain for given handle \n
 | ||
|  |  * outputs\n
 | ||
|  |  * For req #DSPRPC_CONTROL_LATENCY, output is same as API return value \n
 | ||
|  |  * For req #DSPRPC_GET_DSP_INFO, output is capability argument from #remote_dsp_capability \n
 | ||
|  |  * For req #DSPRPC_CONTROL_WAKELOCK, output is  same as API return value \n
 | ||
|  |  * For req #DSPRPC_GET_DOMAIN, output is domain argument from #remote_rpc_get_domain \n
 | ||
|  |  *
 | ||
|  |  * @param[in] datalen Length of the struct defintion used for input params
 | ||
|  |  *
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error codes due to incorrect input arguments are AEE_EBADPARM, AEE_EINVHANDLE, AEE_EUNSUPPORTED
 | ||
|  |  * Other than these error codes, treated as returned from fastRPC framework issues.
 | ||
|  |  *
 | ||
|  |  * For example:
 | ||
|  |  * @code
 | ||
|  |  * struct remote_rpc_control_latency data;
 | ||
|  |  * data.enable = 1;
 | ||
|  |  * data.latency = 100;
 | ||
|  |  *
 | ||
|  |  * if (remote_handle64_control)
 | ||
|  |  *    remote_handle64_control(h, DSPRPC_CONTROL_LATENCY, (void*)&data, sizeof(data));
 | ||
|  |  * else
 | ||
|  |  *    printf("remote_handle64_control not available on this target");
 | ||
|  |  * @endcode
 | ||
|  | */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_handle64_control)(remote_handle64 h, uint32_t req, void* data, uint32_t datalen) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @enum session_control_req_id
 | ||
|  |  * @brief different types of request ID that are passed to the remote session control
 | ||
|  |  */
 | ||
|  | enum session_control_req_id {
 | ||
|  |   FASTRPC_THREAD_PARAMS             = 1,      /**< thread params */
 | ||
|  |   DSPRPC_CONTROL_UNSIGNED_MODULE    = 2,      /**< unsigned PD */
 | ||
|  |   FASTRPC_RELATIVE_THREAD_PRIORITY  = 4,      /**< relative thread priority */
 | ||
|  |   FASTRPC_REMOTE_PROCESS_KILL       = 6,      /**< Kill remote process */
 | ||
|  |   FASTRPC_SESSION_CLOSE             = 7,      /**< Close all open handles of requested domain */
 | ||
|  |   FASTRPC_CONTROL_PD_DUMP           = 8,      /**< Enable PD dump feature */
 | ||
|  |   FASTRPC_REMOTE_PROCESS_EXCEPTION  = 9,      /**< Trigger Exception in the remote process */
 | ||
|  |   FASTRPC_REMOTE_PROCESS_TYPE       = 10,     /**< Query type of process defined by enum fastrpc_process_type */
 | ||
|  |   FASTRPC_REGISTER_STATUS_NOTIFICATIONS = 11, /**< Enable DSP User process status notifications */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_thread_params
 | ||
|  |  * @brief Argument for setting threads params with request ID FASTRPC_THREAD_PARAMS
 | ||
|  |  */
 | ||
|  | struct remote_rpc_thread_params {
 | ||
|  |     int domain;         /**< Remote subsystem domain ID, pass -1 to set params for all domains */
 | ||
|  |     int prio;           /**< user thread priority (1 to 255), pass -1 to use default */
 | ||
|  |     int stack_size;     /**< user thread stack size in bytes, pass -1 to use default */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_control_unsigned_module
 | ||
|  |  * @brief Argument for setting the unsigned PD with req ID:DSPRPC_CONTROL_UNSIGNED_MODULE
 | ||
|  |  */
 | ||
|  | struct remote_rpc_control_unsigned_module {
 | ||
|  |    int domain;              /**<  Remote subsystem domain ID, -1 to set params for all domains */
 | ||
|  |    int enable;              /**<  Non-zero value to set unsigned PD */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_relative_thread_priority
 | ||
|  |  * @brief Argument for setting the relative thread priority with request id:FASTRPC_RELATIVE_THREAD_PRIORITY
 | ||
|  |  */
 | ||
|  | struct remote_rpc_relative_thread_priority {
 | ||
|  |     int domain;                     /**< Remote subsystem domain ID, pass -1 to update priority for all domains */
 | ||
|  |     int relative_thread_priority;   /**< Relative thread priority increased w.r.t to default priority. Negative value will increase priority. Positive value will decrease priority */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_process_clean_params
 | ||
|  |  * @brief Argument for cleaning remote session on DSP with request id:FASTRPC_REMOTE_PROCESS_KILL
 | ||
|  |  */
 | ||
|  | struct remote_rpc_process_clean_params {
 | ||
|  |    int domain;          /**< Remote subsystem domain ID, domain ID of process to recover */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_session_close
 | ||
|  |  * @brief Argument for closing all handles for all domains with request id:FASTRPC_SESSION_CLOSE
 | ||
|  |  */
 | ||
|  | struct remote_rpc_session_close {
 | ||
|  |    int domain;          /**< Remote subsystem domain ID, pass -1 to close all handles for all domains */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_control_pd_dump
 | ||
|  |  * @brief Argument for enabling PD dump on User PD of DSP with request id:FASTRPC_CONTROL_PD_DUMP
 | ||
|  |  */
 | ||
|  | struct remote_rpc_control_pd_dump {
 | ||
|  |    int domain;          /**< Remote subsystem domain ID, pass -1 to enable PD dump on all domains */
 | ||
|  |    int enable;          /**<  1 to enable PD dump, 0 to disable PD dump */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_process_type
 | ||
|  |  * Structure for remote_session_control, used with FASTRPC_REMOTE_PROCESS_TYPE request ID to query the type of PD runs on, defined by enum fastrpc_process_type
 | ||
|  |  * @param[in] : Domain of process
 | ||
|  |  * @param[out]: process_type belonging to enum fastrpc_process_type
 | ||
|  |  */
 | ||
|  | struct remote_process_type {
 | ||
|  |    int domain;
 | ||
|  |    int process_type;
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_process_clean_params
 | ||
|  |  * @brief Argument to trigger exception in the User PD of DSP with request id:FASTRPC_REMOTE_PROCESS_EXCEPTION
 | ||
|  |  */
 | ||
|  | typedef struct remote_rpc_process_clean_params remote_rpc_process_exception;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @enum remote_rpc_status_flags
 | ||
|  |  * @brief different types of DSP User PD status notification flags
 | ||
|  |  */
 | ||
|  | typedef enum remote_rpc_status_flags {
 | ||
|  |    FASTRPC_USER_PD_UP          = 0,    /**< DSP user process is up */
 | ||
|  |    FASTRPC_USER_PD_EXIT        = 1,    /**< DSP user process exited */
 | ||
|  |    FASTRPC_USER_PD_FORCE_KILL  = 2,    /**< DSP user process forcefully killed. Happens when DSP resources needs to be freed. */
 | ||
|  |    FASTRPC_USER_PD_EXCEPTION   = 3,    /**< Exception in the user process of DSP. */
 | ||
|  |    FASTRPC_DSP_SSR             = 4,    /**< Subsystem restart of the DSP, where user process is running. */
 | ||
|  | } remote_rpc_status_flags_t;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Notification call back function
 | ||
|  |  * @param[in] context used in the registration
 | ||
|  |  * @param[in] domain of the user process
 | ||
|  |  * @param[in] session id of user process
 | ||
|  |  * @param[in] status of user process
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure.
 | ||
|  |  */
 | ||
|  | typedef int (*fastrpc_notif_fn_t)(void *context, int domain, int session, remote_rpc_status_flags_t status);
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @struct remote_rpc_notif_register
 | ||
|  |  * @brief Argument to receive status notifications of user process on DSP, with request ID DSPRPC_REGISTER_STATUS_NOTIFICATIONS
 | ||
|  |  */
 | ||
|  | typedef struct remote_rpc_notif_register {
 | ||
|  |     void *context;                  /**< Context of the client */
 | ||
|  |     int domain;                     /**< Remote domain ID */
 | ||
|  |     fastrpc_notif_fn_t notifier_fn; /**< Notification call back function pointer */
 | ||
|  | } remote_rpc_notif_register_t;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  *  remote_session_control API allows configure the remote session params
 | ||
|  | 
 | ||
|  |  * @param[in]  req is one of enum from #session_control_req_id \n
 | ||
|  |  * Req FASTRPC_THREAD_PARAMS is used for setting the theread stack size and priority \n
 | ||
|  |  * Req DSPRPC_CONTROL_UNSIGNED_MODULE used for setting the unsigned PD \n
 | ||
|  |  * Req FASTRPC_RELATIVE_THREAD_PRIORITY used for setting the relative thread priority \n
 | ||
|  |  *
 | ||
|  |  * @param[in]  data void pointer to struct for input params \n
 | ||
|  |  * struct #remote_rpc_thread_params is used for setting the thread priority and stack size \n
 | ||
|  |  * struct #remote_rpc_control_unsigned_module is used for setting the unsigned PD \n
 | ||
|  |  * struct #remote_rpc_relative_thread_priority is used for setting the relative thread priority \n
 | ||
|  |  *
 | ||
|  |  * @param[in] datalen is length of the struct for input params \n
 | ||
|  |  *
 | ||
|  |  * @return Integer value. Zero for succesfully setting the remote session params. Non-zero for failure. \n
 | ||
|  |  * Expected error codes due to incorrect input arguments are AEE_EBADPARM, AEE_EUNSUPPORTED
 | ||
|  |  * Other than this error codes, treated as returned from fastRPC framework issues.
 | ||
|  |  * For example:
 | ||
|  |  * @code
 | ||
|  |  * if (remote_session_control)
 | ||
|  |  * {
 | ||
|  |  *    struct remote_rpc_control_unsigned_module data;
 | ||
|  |  *
 | ||
|  |  *    data.enable = 1;
 | ||
|  |  *    data.domain = CDSP_DOMAIN_ID;
 | ||
|  |  *    retVal = remote_session_control(DSPRPC_CONTROL_UNSIGNED_MODULE, (void*)&data, sizeof(data));
 | ||
|  |  *    printf("remote_session_control returned %d for configuring unsigned PD", retVal);
 | ||
|  |  * }
 | ||
|  |  * else{
 | ||
|  |  *    printf("Unsigned PD not supported on this device.\n");
 | ||
|  |  * }
 | ||
|  |  * @endcode
 | ||
|  | */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_session_control)(uint32_t req, void *data, uint32_t datalen) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  *  remote_mmap API maps the pages on remote domain
 | ||
|  |  *
 | ||
|  |  * @param[in] fd  file descriptor for given buffer
 | ||
|  |  * @param[in] flags  one of enum from #remote_mem_map_flags.
 | ||
|  |  * @param[in] vaddrin HLOS address for given buffer
 | ||
|  |  * @param[in] size Length of the given buffer
 | ||
|  |  * @param[out] vaddrout virtual address on remote domain
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EBADPARM.
 | ||
|  |  * Other than these error codes, treated as returned from fastRPC framework issues.
 | ||
|  |  * For example:
 | ||
|  |  * @code
 | ||
|  |  * int nErr = 0
 | ||
|  |  * if (remote_mem_map) {
 | ||
|  |  *    nErr = remote_mem_map(domain, fd, flags, buf, size, remoteVirtAddr);
 | ||
|  |  * } else {
 | ||
|  |  *    // symbol not found. Fall back to old API
 | ||
|  |  *    nErr = remote_mmap64(fd, flags, buf, size, remoteVirtAddr);
 | ||
|  |  * }
 | ||
|  |  * return nErr;
 | ||
|  |  * @endcode
 | ||
|  | */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_mmap)(int fd, uint32_t flags, uint32_t vaddrin, int size, uint32_t* vaddrout) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  |  /**
 | ||
|  |  * remote_unmap API unmaps the pages on remote domain
 | ||
|  |  * @param[in] vaddrout virtual address returned via #remote_mmap()
 | ||
|  |  * @param[in] size Length of the given buffer
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EBADPARM.
 | ||
|  |  * Other than these error codes, treated as returned from fastRPC framework issues.
 | ||
|  | */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_munmap)(uint32_t vaddrout, int size) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @enum remote_mem_map_flags
 | ||
|  |  * @brief Different set of flags for mapping the buffer on remote process domain\n
 | ||
|  |  * Create static memory map on remote process with default cache configuration (writeback).
 | ||
|  |  * Same remoteVirtAddr will be assigned on remote process when fastrpc call made with local virtual address.
 | ||
|  |  * Map scope:
 | ||
|  |  * Life time of this mapping is until user unmap using remote_mem_unmap or session close.
 | ||
|  |  * No reference counts are used. Behavior of mapping multiple times without unmap is undefined.
 | ||
|  |  * Cache maintenance:
 | ||
|  |  * Driver clean caches when virtual address passed through RPC calls defined in IDL as a pointer.
 | ||
|  |  * User is responsible for cleaning cache when remoteVirtAddr shared to DSP and accessed out of fastrpc method invocations on DSP.
 | ||
|  |  * recommended usage:
 | ||
|  |  * Map buffers which are reused for long time or until session close. This helps to reduce fastrpc latency.
 | ||
|  |  * Memory shared with remote process and accessed only by DSP.
 | ||
|  |  */
 | ||
|  | 
 | ||
|  | enum remote_mem_map_flags {
 | ||
|  |    REMOTE_MAP_MEM_STATIC      = 0,
 | ||
|  |    REMOTE_MAP_MAX_FLAG        = REMOTE_MAP_MEM_STATIC + 1,
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Map memory to the remote process on a selected DSP domain
 | ||
|  |  * @param[in] domain DSP domain ID. Use -1 for using default domain\n
 | ||
|  |  *          Default domain is selected based on library lib(a/m/s/c)dsprpc.so library linked to application.
 | ||
|  |  * @param[in] fd file descriptor of memory
 | ||
|  |  * @param[in] flags one of enum from #remote_mem_map_flags
 | ||
|  |  * @param[in] virtAddr virtual address of buffer
 | ||
|  |  * @param[in] size buffer length
 | ||
|  |  * @param[out] remoteVirtAddr remote process virtual address
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EBADPARM
 | ||
|  |  * Other than these error codes, treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_mem_map)(int domain, int fd, int flags, uint64_t virtAddr, size_t size, uint64_t* remoteVirtAddr) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Unmap memory to the remote process on a selected DSP domain
 | ||
|  |  * @param[in] domain DSP domain ID. Use -1 for using default domain. Get domain from multi-domain handle if required.
 | ||
|  |  * @param[in] remoteVirtAddr virtual address returned via #remote_mem_map()
 | ||
|  |  * @param[in] size buffer length
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EBADPARM
 | ||
|  |  * Other than this error code, treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_mem_unmap)(int domain, uint64_t remoteVirtAddr, size_t size) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @enum remote_buf_attributes
 | ||
|  |  * @brief Types of buffer attributes
 | ||
|  |  */
 | ||
|  | enum remote_buf_attributes {
 | ||
|  |    FASTRPC_ATTR_NON_COHERENT        = 2,    /**< Attribute to map a buffer as DMA non-coherent Driver perform cache maintenance. */
 | ||
|  |    FASTRPC_ATTR_COHERENT            = 4,    /**< Attribute to map a buffer as DMA coherent Driver skips cache maintenenace.
 | ||
|  |                                                  It will be ignored if a device is marked as DMA-coherent in device tree. */
 | ||
|  |    FASTRPC_ATTR_KEEP_MAP            = 8,    /**< Attribute to keep the buffer persistant until unmap is called explicitly */
 | ||
|  |    FASTRPC_ATTR_NOMAP               = 16,   /**< Attribute for secure buffers to skip  smmu mapping in fastrpc driver */
 | ||
|  |    FASTRPC_ATTR_FORCE_NOFLUSH       = 32,   /**< Attribute to map buffer such that flush by driver is skipped for that particular buffer.
 | ||
|  |                                                  Client has to perform cache maintenance. */
 | ||
|  |    FASTRPC_ATTR_FORCE_NOINVALIDATE  = 64,   /**< Attribute to map buffer such that invalidate by driver is skipped for that particular buffer.
 | ||
|  |                                                  Client has to perform cache maintenance. */
 | ||
|  |    FASTRPC_ATTR_TRY_MAP_STATIC      = 128,  /**< Attribute for persistent mapping a buffer to remote DSP
 | ||
|  |                                                  process during buffer registration with the FastRPC driver.
 | ||
|  |                                                  This buffer will be automatically mapped during session
 | ||
|  |                                                  open and unmapped either at session close or buffer
 | ||
|  |                                                  unregistration. The FastRPC library treis to map buffers
 | ||
|  |                                                  and ignores error in case of failure. Pre-mapping a buffer    reduces the FastRPC latency. This flag is recommended only
 | ||
|  |                                                  for buffers used with latency-critical FastRPC calls. */
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /** Register a file descriptor for a user allocated buffer(Other than rpcmem_alloc). This is only valid on
 | ||
|  |  * Android with ION allocated memory. Users of fastRPC should register
 | ||
|  |  * a buffer allocated with ION to enable sharing that buffer to the
 | ||
|  |  * DSP via the SMMU. If user allocated buffers not registered via this API
 | ||
|  |  * remote calls are expected to take more latency where these user buffers are passed.
 | ||
|  |  * Some versions of libadsprpc.so lack this function, so users should set
 | ||
|  |  * this symbol as weak.\n
 | ||
|  |  * `pragma weak  remote_register_buf_attr`\n
 | ||
|  |  * @param[in] buf virtual address of the buffer
 | ||
|  |  * @param[in] size size of the buffer
 | ||
|  |  * @param[in] fd file descriptor, callers can use -1 to deregister.
 | ||
|  |  * @param[in] attr map buffer as coherent or non-coherent \n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EBADPARM. Other than this error
 | ||
|  |  * codes treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | 
 | ||
|  |  __QAIC_REMOTE_EXPORT void __QAIC_REMOTE(remote_register_buf_attr)(void* buf, int size, int fd, int attr) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /** Register a file descriptor for a user allocated buffer(Other than rpcmem_alloc). This is only valid on
 | ||
|  |  * Android with ION allocated memory. Users of fastRPC should register
 | ||
|  |  * a buffer allocated with ION to enable sharing that buffer to the
 | ||
|  |  * DSP via the SMMU. If user allocated buffers not registered via this API
 | ||
|  |  * remote calls are expected to take more latency where these user buffers are passed.
 | ||
|  |  * Some versions of libadsprpc.so lack this function, so users should set
 | ||
|  |  * this symbol as weak.\n
 | ||
|  |  * pragma weak  remote_register_buf\n
 | ||
|  |  * @param[in] buf virtual address of the buffer
 | ||
|  |  * @param[in] size size of the buffer
 | ||
|  |  * @param[in] fd file descriptor, callers can use -1 to deregister \n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EBADPARM. Other than this error
 | ||
|  |  * codes treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT void __QAIC_REMOTE(remote_register_buf)(void* buf, int size, int fd) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /** Register a DMA handle with fastrpc.  This is only valid on
 | ||
|  |  * android with ION allocated memory.  Users of fastrpc should register
 | ||
|  |  * a file descriptor allocated with ION to enable sharing that memory to the
 | ||
|  |  * dsp via the smmu.  Some versions of libadsprpc.so lack this
 | ||
|  |  * function, so users should set this symbol as weak.\n
 | ||
|  |  *
 | ||
|  |  * `pragma weak  remote_register_dma_handle`\n
 | ||
|  |  * `pragma weak  remote_register_dma_handle_attr`\n
 | ||
|  |  * @param[in] fd file descriptor, callers can use -1 to deregister.
 | ||
|  |  * @param[in] len size of the buffer
 | ||
|  |  * @param[in]  attr map buffer as coherent or non-coherent or no-map\n
 | ||
|  |  * Expected error codes due to incorrect input arguments are AEE_EBADPARM, AEE_EINVHANDLE. Other than these error codes,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_register_dma_handle_attr)(int fd, uint32_t len, uint32_t attr) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /** Register a DMA handle with fastrpc.  This is only valid on
 | ||
|  |  * android with ION allocated memory.  Users of fastrpc should register
 | ||
|  |  * a file descriptor allocated with ION to enable sharing that memory to the
 | ||
|  |  * dsp via the smmu.  Some versions of libadsprpc.so lack this
 | ||
|  |  * function, so users should set this symbol as weak.\n
 | ||
|  |  *
 | ||
|  |  * pragma weak  remote_register_dma_handle\n
 | ||
|  |  * @param[in] fd file descriptor, callers can use -1 to deregister.
 | ||
|  |  * @param[in] len size of the buffer \n
 | ||
|  |  * Expected error codes due to incorrect input arguments are AEE_EBADPARM, AEE_EINVHANDLE. Other than these error codes,
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_register_dma_handle)(int fd, uint32_t len) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /** Register a file descriptor.  This can be used when users do not have
 | ||
|  |  * a mapping to pass to the RPC layer.  The generated address is a mapping
 | ||
|  |  * with PROT_NONE, any access to this memory will fail, so it should only
 | ||
|  |  * be used as an ID to identify this file descriptor to the RPC layer.
 | ||
|  |  *
 | ||
|  |  * To deregister use remote_register_buf(addr, size, -1).
 | ||
|  |  *
 | ||
|  |  * `pragma weak  remote_register_fd`\n
 | ||
|  |  * @param[in] fd is the file descriptor.
 | ||
|  |  * @param[in] size length the buffer
 | ||
|  |  * @return (void*)-1 on failure, address on success.\n
 | ||
|  |  * All error codes treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT void *__QAIC_REMOTE(remote_register_fd)(int fd, int size) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /** Get status of Async job.  This can be used to query the status of a Async job
 | ||
|  |  *
 | ||
|  |  * @param[in] jobid  returned during Async job submission via #remote_handle_invoke_async()
 | ||
|  |  * @param[in] timeout_us in micro seconds \n
 | ||
|  |  *                    timeout = 0, returns immediately with status/result\n
 | ||
|  |  *                    timeout > 0, waits for specified time and then returns with status/result \n
 | ||
|  |  *                    timeout < 0. waits indefinetely until job completes \n
 | ||
|  |  * @param[out] result ouptput pointer \n
 | ||
|  |  *                0 on success\n
 | ||
|  |  *                error code on failure\n
 | ||
|  |  * @return 0 on job completion\n
 | ||
|  |  *          if job status is pending, it is not returned from DSP\n
 | ||
|  |  * Expected error code due to incorrect input arguments is AEE_EBADPARM. Other than this error code
 | ||
|  |  * treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(fastrpc_async_get_status)(fastrpc_async_jobid jobid, int timeout_us, int *result);
 | ||
|  | 
 | ||
|  | /** Release Async job.  Release async job after receiving status either through callback/poll
 | ||
|  |  *
 | ||
|  |  * @param[in] jobid returned during Async job submission via #remote_handle_invoke_async()
 | ||
|  |  * @return  Zero for success. Non-zero for failure.\n
 | ||
|  |  *          AEE_EBUSY, if job status is pending and is not returned from DSP\n
 | ||
|  |  *          AEE_EBADPARM, if job id is invalid \n
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(fastrpc_release_async_job)(fastrpc_async_jobid jobid);
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * By default, Driver runs Parallel mode
 | ||
|  |  */
 | ||
|  | #define REMOTE_MODE_PARALLEL  0
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * When operating in SERIAL mode the driver will invalidate output buffers
 | ||
|  |  * before calling into the dsp.  This mode should be used when output
 | ||
|  |  * buffers have been written to somewhere besides the aDSP.
 | ||
|  |  */
 | ||
|  | #define REMOTE_MODE_SERIAL    1
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Internal transport prefix
 | ||
|  |  */
 | ||
|  | #define ITRANSPORT_PREFIX "'\":;./\\"
 | ||
|  | 
 | ||
|  | /** remote_set_mode API will be  deprecated in near future. It is discouraged to use this API.\n
 | ||
|  |  * Set the mode of operation.\n
 | ||
|  |  * This is the default mode for the driver.  While the driver is in parallel
 | ||
|  |  * mode it will try to invalidate output buffers after it transfers control
 | ||
|  |  * to the dsp.  This allows the invalidate operations to overlap with the
 | ||
|  |  * dsp processing the call.  This mode should be used when output buffers
 | ||
|  |  * are only read on the application processor and only written on the aDSP.
 | ||
|  |  * Some versions of libadsprpc.so lack this function, so users should set
 | ||
|  |  * this symbol as weak.\n
 | ||
|  |  * `pragma weak  remote_set_mode`
 | ||
|  |  * @param[in] mode serial/parallel operation
 | ||
|  |  * @return Integer value. Zero for success and non-zero for failure. For failure, returns error code.\n
 | ||
|  |  * All error codes, treated as returned from fastRPC framework issues.
 | ||
|  |  */
 | ||
|  | __QAIC_REMOTE_EXPORT int __QAIC_REMOTE(remote_set_mode)(uint32_t mode) __QAIC_REMOTE_ATTRIBUTE;
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @enum fastrpc_map_flags
 | ||
|  |  * @brief Types of maps with cache maintenance
 | ||
|  |  */
 | ||
|  | enum fastrpc_map_flags {
 | ||
|  |     /**
 | ||
|  |      * Map memory pages with RW- permission and CACHE WRITEBACK.
 | ||
|  |      * Driver will clean cache when buffer passed in a FastRPC call.
 | ||
|  |      * Same remote virtual address will be assigned for subsequent
 | ||
|  |      * FastRPC calls.
 | ||
|  |      */
 | ||
|  |     FASTRPC_MAP_STATIC = 0,
 | ||
|  | 
 | ||
|  |     /* Reserved for compatibility with deprecated flag */
 | ||
|  |     FASTRPC_MAP_RESERVED = 1,
 | ||
|  | 
 | ||
|  |     /**
 | ||
|  |      * Map memory pages with RW- permission and CACHE WRITEBACK.
 | ||
|  |      * Mapping tagged with a file descriptor. User is responsible for
 | ||
|  |      * maintenance of CPU and DSP caches for the buffer. Get virtual address
 | ||
|  |      * of buffer on DSP using HAP_mmap_get() and HAP_mmap_put() functions.
 | ||
|  |      */
 | ||
|  |     FASTRPC_MAP_FD = 2,
 | ||
|  | 
 | ||
|  |     /**
 | ||
|  |      * Mapping delayed until user calls HAP_mmap() and HAP_munmap()
 | ||
|  |      * functions on DSP. User is responsible for maintenance of CPU and DSP
 | ||
|  |      * caches for the buffer. Delayed mapping is useful for users to map
 | ||
|  |      * buffer on DSP with other than default permissions and cache modes
 | ||
|  |      * using HAP_mmap() and HAP_munmap() functions.
 | ||
|  |      */
 | ||
|  |     FASTRPC_MAP_FD_DELAYED = 3,
 | ||
|  | 
 | ||
|  |     /**
 | ||
|  |      * MAX enum is used internally by the FastRPC library for checking range of valid flags.
 | ||
|  |      * Add new flags above it. Leave unassigned and as last enum value.
 | ||
|  |      */
 | ||
|  |     FASTRPC_MAP_MAX,
 | ||
|  | };
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Creates a mapping on remote process for an ION buffer with file descriptor. A new FastRPC session
 | ||
|  |  * will be opened if not already opened for the domain.
 | ||
|  |  *
 | ||
|  |  * @param domain DSP domain ID of a FastRPC session
 | ||
|  |  * @param fd ION memory file descriptor
 | ||
|  |  * @param addr buffer virtual address on cpu
 | ||
|  |  * @param offset offset from the beginining of the buffer
 | ||
|  |  * @param length size of buffer in bytes
 | ||
|  |  * @param flags controls mapping functionality on DSP. Refer fastrpc_map_flags enum definition for more information.
 | ||
|  |  *
 | ||
|  |  * @return  0 on success, error code on failure.
 | ||
|  |  *          - AEE_EBADPARM Bad parameters
 | ||
|  |  *          - AEE_EFAILED Failed to map buffer
 | ||
|  |  *          - AEE_ENOMEMORY Out of memory (internal error)
 | ||
|  |  *          - AEE_EUNSUPPORTED Unsupported API on the target
 | ||
|  |  */
 | ||
|  | int fastrpc_mmap(int domain, int fd, void *addr, int offset, size_t length, enum fastrpc_map_flags flags);
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * Removes a mapping associated with file descriptor.
 | ||
|  |  *
 | ||
|  |  * @param domain DSP domain ID of a FastRPC session
 | ||
|  |  * @param fd file descriptor
 | ||
|  |  * @param addr buffer virtual address used for mapping creation
 | ||
|  |  * @param length size of buffer mapped in bytes
 | ||
|  |  *
 | ||
|  |  * @return  0 on success, error code on failure.
 | ||
|  |  *          - AEE_EBADPARM Bad parameters e.g. Mapping not found for specified fd
 | ||
|  |  *          - AEE_EFAILED Failed to map buffer
 | ||
|  |  *          - AEE_EUNSUPPORTED Unsupported API on the target
 | ||
|  |  */
 | ||
|  | int fastrpc_munmap(int domain, int fd, void *addr, size_t length);
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | }
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #endif // REMOTE_DEFAULT_H
 |