xref: /aosp_15_r20/external/fastrpc/inc/apps_std.h (revision 418b791d679beb2078b579a3b6936cf330c41799)
1*418b791dSBob Badour /**
2*418b791dSBob Badour  * Copyright (c) 2019, The Linux Foundation. All rights reserved.
3*418b791dSBob Badour  *
4*418b791dSBob Badour  * Redistribution and use in source and binary forms, with or without
5*418b791dSBob Badour  * modification, are permitted provided that the following conditions are
6*418b791dSBob Badour  * met:
7*418b791dSBob Badour  *    * Redistributions of source code must retain the above copyright
8*418b791dSBob Badour  *      notice, this list of conditions and the following disclaimer.
9*418b791dSBob Badour  *    * Redistributions in binary form must reproduce the above
10*418b791dSBob Badour  *      copyright notice, this list of conditions and the following
11*418b791dSBob Badour  *      disclaimer in the documentation and/or other materials provided
12*418b791dSBob Badour  *      with the distribution.
13*418b791dSBob Badour  *    * Neither the name of The Linux Foundation nor the names of its
14*418b791dSBob Badour  *      contributors may be used to endorse or promote products derived
15*418b791dSBob Badour  *      from this software without specific prior written permission.
16*418b791dSBob Badour  *
17*418b791dSBob Badour  * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
18*418b791dSBob Badour  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19*418b791dSBob Badour  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
20*418b791dSBob Badour  * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
21*418b791dSBob Badour  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22*418b791dSBob Badour  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23*418b791dSBob Badour  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
24*418b791dSBob Badour  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25*418b791dSBob Badour  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
26*418b791dSBob Badour  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
27*418b791dSBob Badour  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*418b791dSBob Badour  */
29*418b791dSBob Badour 
30*418b791dSBob Badour #ifndef _APPS_STD_H
31*418b791dSBob Badour #define _APPS_STD_H
32*418b791dSBob Badour #include "AEEStdDef.h"
33*418b791dSBob Badour #ifndef __QAIC_HEADER
34*418b791dSBob Badour #define __QAIC_HEADER(ff) ff
35*418b791dSBob Badour #endif //__QAIC_HEADER
36*418b791dSBob Badour 
37*418b791dSBob Badour #ifndef __QAIC_HEADER_EXPORT
38*418b791dSBob Badour #define __QAIC_HEADER_EXPORT
39*418b791dSBob Badour #endif // __QAIC_HEADER_EXPORT
40*418b791dSBob Badour 
41*418b791dSBob Badour #ifndef __QAIC_HEADER_ATTRIBUTE
42*418b791dSBob Badour #define __QAIC_HEADER_ATTRIBUTE
43*418b791dSBob Badour #endif // __QAIC_HEADER_ATTRIBUTE
44*418b791dSBob Badour 
45*418b791dSBob Badour #ifndef __QAIC_IMPL
46*418b791dSBob Badour #define __QAIC_IMPL(ff) ff
47*418b791dSBob Badour #endif //__QAIC_IMPL
48*418b791dSBob Badour 
49*418b791dSBob Badour #ifndef __QAIC_IMPL_EXPORT
50*418b791dSBob Badour #define __QAIC_IMPL_EXPORT
51*418b791dSBob Badour #endif // __QAIC_IMPL_EXPORT
52*418b791dSBob Badour 
53*418b791dSBob Badour #ifndef __QAIC_IMPL_ATTRIBUTE
54*418b791dSBob Badour #define __QAIC_IMPL_ATTRIBUTE
55*418b791dSBob Badour #endif // __QAIC_IMPL_ATTRIBUTE
56*418b791dSBob Badour #ifdef __cplusplus
57*418b791dSBob Badour extern "C" {
58*418b791dSBob Badour #endif
59*418b791dSBob Badour #if !defined(__QAIC_STRING1_OBJECT_DEFINED__) && !defined(__STRING1_OBJECT__)
60*418b791dSBob Badour #define __QAIC_STRING1_OBJECT_DEFINED__
61*418b791dSBob Badour #define __STRING1_OBJECT__
62*418b791dSBob Badour typedef struct _cstring1_s {
63*418b791dSBob Badour    char* data;
64*418b791dSBob Badour    int dataLen;
65*418b791dSBob Badour } _cstring1_t;
66*418b791dSBob Badour 
67*418b791dSBob Badour #endif /* __QAIC_STRING1_OBJECT_DEFINED__ */
68*418b791dSBob Badour /**
69*418b791dSBob Badour     * standard library functions remoted from the apps to the dsp
70*418b791dSBob Badour     */
71*418b791dSBob Badour typedef int apps_std_FILE;
72*418b791dSBob Badour enum apps_std_SEEK {
73*418b791dSBob Badour    APPS_STD_SEEK_SET,
74*418b791dSBob Badour    APPS_STD_SEEK_CUR,
75*418b791dSBob Badour    APPS_STD_SEEK_END,
76*418b791dSBob Badour    _32BIT_PLACEHOLDER_apps_std_SEEK = 0x7fffffff
77*418b791dSBob Badour };
78*418b791dSBob Badour typedef enum apps_std_SEEK apps_std_SEEK;
79*418b791dSBob Badour typedef struct apps_std_DIR apps_std_DIR;
80*418b791dSBob Badour struct apps_std_DIR {
81*418b791dSBob Badour    uint64 handle;
82*418b791dSBob Badour };
83*418b791dSBob Badour typedef struct apps_std_DIRENT apps_std_DIRENT;
84*418b791dSBob Badour struct apps_std_DIRENT {
85*418b791dSBob Badour    int ino;
86*418b791dSBob Badour    char name[255];
87*418b791dSBob Badour };
88*418b791dSBob Badour typedef struct apps_std_STAT apps_std_STAT;
89*418b791dSBob Badour struct apps_std_STAT {
90*418b791dSBob Badour    uint64 tsz;
91*418b791dSBob Badour    uint64 dev;
92*418b791dSBob Badour    uint64 ino;
93*418b791dSBob Badour    uint32 mode;
94*418b791dSBob Badour    uint32 nlink;
95*418b791dSBob Badour    uint64 rdev;
96*418b791dSBob Badour    uint64 size;
97*418b791dSBob Badour    int64 atime;
98*418b791dSBob Badour    int64 atimensec;
99*418b791dSBob Badour    int64 mtime;
100*418b791dSBob Badour    int64 mtimensec;
101*418b791dSBob Badour    int64 ctime;
102*418b791dSBob Badour    int64 ctimensec;
103*418b791dSBob Badour };
104*418b791dSBob Badour /**
105*418b791dSBob Badour        * @retval, if operation fails errno is returned
106*418b791dSBob Badour        */
107*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fopen)(const char* name, const char* mode, apps_std_FILE* psout) __QAIC_HEADER_ATTRIBUTE;
108*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_freopen)(apps_std_FILE sin, const char* name, const char* mode, apps_std_FILE* psout) __QAIC_HEADER_ATTRIBUTE;
109*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fflush)(apps_std_FILE sin) __QAIC_HEADER_ATTRIBUTE;
110*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fclose)(apps_std_FILE sin) __QAIC_HEADER_ATTRIBUTE;
111*418b791dSBob Badour /**
112*418b791dSBob Badour        * @param,  bEOF, if read or write bytes <= bufLen bytes then feof() is called
113*418b791dSBob Badour        *          and the result is returned in bEOF, otherwise bEOF is set to 0.
114*418b791dSBob Badour        * @retval, if read or write return 0 for non zero length buffers, ferror is checked
115*418b791dSBob Badour        *          and a non zero value is returned in case of error with no rout parameters
116*418b791dSBob Badour        */
117*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fread)(apps_std_FILE sin, byte* buf, int bufLen, int* bytesRead, int* bEOF) __QAIC_HEADER_ATTRIBUTE;
118*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fwrite)(apps_std_FILE sin, const byte* buf, int bufLen, int* bytesWritten, int* bEOF) __QAIC_HEADER_ATTRIBUTE;
119*418b791dSBob Badour /**
120*418b791dSBob Badour        * @param, pos, this buffer is filled up to MIN(posLen, sizeof(fpos_t))
121*418b791dSBob Badour        * @param, posLenReq, returns sizeof(fpos_t)
122*418b791dSBob Badour        * @retval, if operation fails errno is returned
123*418b791dSBob Badour        */
124*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fgetpos)(apps_std_FILE sin, byte* pos, int posLen, int* posLenReq) __QAIC_HEADER_ATTRIBUTE;
125*418b791dSBob Badour /**
126*418b791dSBob Badour        * @param, if size of pos doesn't match the system size an error is returned.
127*418b791dSBob Badour        *         fgetpos can be used to query the size of fpos_t
128*418b791dSBob Badour        * @retval, if operation fails errno is returned
129*418b791dSBob Badour        */
130*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fsetpos)(apps_std_FILE sin, const byte* pos, int posLen) __QAIC_HEADER_ATTRIBUTE;
131*418b791dSBob Badour /**
132*418b791dSBob Badour        * @retval, if operation fails errno is returned
133*418b791dSBob Badour        */
134*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_ftell)(apps_std_FILE sin, int* pos) __QAIC_HEADER_ATTRIBUTE;
135*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fseek)(apps_std_FILE sin, int offset, apps_std_SEEK whence) __QAIC_HEADER_ATTRIBUTE;
136*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_flen)(apps_std_FILE sin, uint64* len) __QAIC_HEADER_ATTRIBUTE;
137*418b791dSBob Badour /**
138*418b791dSBob Badour        * @retval, only fails if transport fails
139*418b791dSBob Badour        */
140*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_rewind)(apps_std_FILE sin) __QAIC_HEADER_ATTRIBUTE;
141*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_feof)(apps_std_FILE sin, int* bEOF) __QAIC_HEADER_ATTRIBUTE;
142*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_ferror)(apps_std_FILE sin, int* err) __QAIC_HEADER_ATTRIBUTE;
143*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_clearerr)(apps_std_FILE sin) __QAIC_HEADER_ATTRIBUTE;
144*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_print_string)(const char* str) __QAIC_HEADER_ATTRIBUTE;
145*418b791dSBob Badour /**
146*418b791dSBob Badour        * @param val, must contain space for NULL
147*418b791dSBob Badour        * @param valLenReq, length required with NULL
148*418b791dSBob Badour        * @retval, if fails errno is returned
149*418b791dSBob Badour        */
150*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_getenv)(const char* name, char* val, int valLen, int* valLenReq) __QAIC_HEADER_ATTRIBUTE;
151*418b791dSBob Badour /**
152*418b791dSBob Badour        * @retval, if fails errno is returned
153*418b791dSBob Badour        */
154*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_setenv)(const char* name, const char* val, int override) __QAIC_HEADER_ATTRIBUTE;
155*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_unsetenv)(const char* name) __QAIC_HEADER_ATTRIBUTE;
156*418b791dSBob Badour /**
157*418b791dSBob Badour        * This function will try to open a file given directories in envvarname separated by
158*418b791dSBob Badour        * delim.
159*418b791dSBob Badour        * so given environment variable FOO_PATH=/foo;/bar
160*418b791dSBob Badour        *    fopen_wth_env("FOO_PATH", ";", "path/to/file", "rw", &out);
161*418b791dSBob Badour        * will try to open /foo/path/to/file, /bar/path/to/file
162*418b791dSBob Badour        * if the variable is unset, it will open the file directly
163*418b791dSBob Badour        *
164*418b791dSBob Badour        * @param envvarname, name of the environment variable containing the path
165*418b791dSBob Badour        * @param delim, delimiator string, such as ";"
166*418b791dSBob Badour        * @param name, name of the file
167*418b791dSBob Badour        * @param mode, mode
168*418b791dSBob Badour        * @param psout, output handle
169*418b791dSBob Badour        * @retval, 0 on success errno or -1 on failure
170*418b791dSBob Badour        */
171*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fopen_with_env)(const char* envvarname, const char* delim, const char* name, const char* mode, apps_std_FILE* psout) __QAIC_HEADER_ATTRIBUTE;
172*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fgets)(apps_std_FILE sin, byte* buf, int bufLen, int* bEOF) __QAIC_HEADER_ATTRIBUTE;
173*418b791dSBob Badour /**
174*418b791dSBob Badour        * This method will return the paths that are searched when looking for a file.
175*418b791dSBob Badour        *  The paths are defined by the environment variable (separated by delimiters)
176*418b791dSBob Badour        *  that is passed to the method.
177*418b791dSBob Badour        *
178*418b791dSBob Badour        * @param envvarname, name of the environment variable containing the path
179*418b791dSBob Badour        * @param delim, delimiator string, such as ";"
180*418b791dSBob Badour        * @param name, name of the file
181*418b791dSBob Badour        * @param paths, Search paths
182*418b791dSBob Badour        * @param numPaths, Actual number of paths found
183*418b791dSBob Badour        * @param maxPathLen, The max path length
184*418b791dSBob Badour        * @retval, 0 on success errno or -1 on failure
185*418b791dSBob Badour        *
186*418b791dSBob Badour        */
187*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_get_search_paths_with_env)(const char* envvarname, const char* delim, _cstring1_t* paths, int pathsLen, uint32* numPaths, uint16* maxPathLen) __QAIC_HEADER_ATTRIBUTE;
188*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fileExists)(const char* path, boolean* exists) __QAIC_HEADER_ATTRIBUTE;
189*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fsync)(apps_std_FILE sin) __QAIC_HEADER_ATTRIBUTE;
190*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fremove)(const char* name) __QAIC_HEADER_ATTRIBUTE;
191*418b791dSBob Badour /**
192*418b791dSBob Badour         * This function decrypts the file using the provided open file descriptor, closes the
193*418b791dSBob Badour         * original descriptor and return a new file descriptor.
194*418b791dSBob Badour         * @retval, if operation fails errno is returned
195*418b791dSBob Badour         */
196*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_fdopen_decrypt)(apps_std_FILE sin, apps_std_FILE* psout) __QAIC_HEADER_ATTRIBUTE;
197*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_opendir)(const char* name, apps_std_DIR* dir) __QAIC_HEADER_ATTRIBUTE;
198*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_closedir)(const apps_std_DIR* dir) __QAIC_HEADER_ATTRIBUTE;
199*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_readdir)(const apps_std_DIR* dir, apps_std_DIRENT* dirent, int* bEOF) __QAIC_HEADER_ATTRIBUTE;
200*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_mkdir)(const char* name, int mode) __QAIC_HEADER_ATTRIBUTE;
201*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_rmdir)(const char* name) __QAIC_HEADER_ATTRIBUTE;
202*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_stat)(const char* name, apps_std_STAT* stat) __QAIC_HEADER_ATTRIBUTE;
203*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_ftrunc)(apps_std_FILE sin, int offset) __QAIC_HEADER_ATTRIBUTE;
204*418b791dSBob Badour __QAIC_HEADER_EXPORT int __QAIC_HEADER(apps_std_frename)(const char* oldname, const char* newname) __QAIC_HEADER_ATTRIBUTE;
205*418b791dSBob Badour #ifdef __cplusplus
206*418b791dSBob Badour }
207*418b791dSBob Badour #endif
208*418b791dSBob Badour #endif //_APPS_STD_H
209