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