| /****************************************************************************** |
| * |
| * Copyright (C) 2000-2012 Broadcom Corporation |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at: |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| * |
| ******************************************************************************/ |
| #ifndef GOEP_FS_H |
| #define GOEP_FS_H |
| |
| #include "bt_target.h" |
| |
| /***************************************************************************** |
| ** Constants |
| *****************************************************************************/ |
| |
| /* Flags passed to the open function (tGOEP_OPEN_CBACK) |
| ** Values are OR'd together. (First 3 are |
| ** mutually exclusive. |
| */ |
| #define GOEP_O_RDONLY 0x0000 |
| #define GOEP_O_WRONLY 0x0001 |
| #define GOEP_O_RDWR 0x0002 |
| |
| #define GOEP_O_CREAT 0x0100 |
| #define GOEP_O_EXCL 0x0200 |
| #define GOEP_O_TRUNC 0x1000 |
| |
| |
| #define GOEP_LEN_UNKNOWN 0xFFFFFFFF |
| #define GOEP_INVALID_FD (-1) |
| |
| /* Values passed to the access function (tGOEP_ACCESS_CBACK) |
| */ |
| #define GOEP_ACC_EXIST 0x0 |
| #define GOEP_ACC_READ 0x4 |
| #define GOEP_ACC_RDWR 0x6 |
| |
| /* Constants used in directory listing structure */ |
| #define GOEP_A_RDONLY 0x1 |
| #define GOEP_A_DIR 0x2 /* Entry is a sub directory */ |
| |
| #define GOEP_CTIME_LEN 17 /* Creation time "yyyymmddTHHMMSSZ" */ |
| |
| /***************************************************************************** |
| ** Seek Constants |
| *****************************************************************************/ |
| /* Origin for the seek function (tGOEP_SEEK_CBACK) */ |
| #define GOEP_SEEK_SET 0 |
| #define GOEP_SEEK_CUR 1 |
| #define GOEP_SEEK_END 2 |
| |
| |
| |
| /***************************************************************************** |
| ** Typedefs |
| *****************************************************************************/ |
| typedef INT32 tGOEP_FD; |
| |
| enum |
| { |
| GOEP_OK, |
| GOEP_FAIL, |
| GOEP_EACCES, |
| GOEP_ENOTEMPTY, |
| GOEP_EOF, |
| GOEP_EODIR, |
| GOEP_ENOSPACE, |
| GOEP_EIS_DIR, |
| GOEP_RESUME, |
| GOEP_NONE |
| }; |
| typedef UINT16 tGOEP_STATUS; |
| |
| /* Structure passed in Directory Entry Callback to be filled in */ |
| typedef struct |
| { |
| UINT32 refdata; /* holder for OS specific data used to get next entry */ |
| UINT32 filesize; |
| char crtime[GOEP_CTIME_LEN]; /* "yyyymmddTHHMMSSZ", or "" if none */ |
| char *p_name; /* Contains the addr of memory to copy name into */ |
| UINT8 mode; /* GOEP_A_RDONLY and/or GOEP_A_DIR */ |
| } tGOEP_DIRENTRY; |
| |
| |
| /***************************************************************************** |
| ** Typedefs for messages from response functions |
| *****************************************************************************/ |
| typedef struct |
| { |
| BT_HDR hdr; |
| tGOEP_FD fd; |
| tGOEP_STATUS status; |
| UINT32 file_size; |
| } tGOEP_OPEN_RSP; |
| |
| typedef struct |
| { |
| BT_HDR hdr; |
| tGOEP_FD fd; |
| tGOEP_STATUS status; |
| UINT16 bytes_read; |
| } tGOEP_READ_RSP; |
| |
| typedef struct |
| { |
| BT_HDR hdr; |
| tGOEP_FD fd; |
| tGOEP_STATUS status; |
| } tGOEP_WRITE_RSP; |
| |
| typedef struct |
| { |
| BT_HDR hdr; |
| tGOEP_STATUS status; |
| } tGOEP_DIRENTRY_RSP; |
| |
| /***************************************************************************** |
| ** Object Store Interface |
| *****************************************************************************/ |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_OPEN_CBACK |
| ** |
| ** Description This function is executed by OBX profiles to open |
| ** a file for reading or writing. |
| ** |
| ** Parameters p_path - Fully qualified path and file name. |
| ** flags - permissions and mode (see constants above) |
| ** size - size of file to put (0 if unavailable or not applicable) |
| ** event_id - code that must be passed to the call-in function. |
| ** |
| ** Returns void |
| ** |
| ** Note: Upon completion of the request, a file descriptor (tGOEP_FD), |
| ** file size (UINT32), and an status code (tGOEP_STATUS) |
| ** are returned in GOEP_OpenRsp(). |
| ** |
| *******************************************************************************/ |
| typedef void (tGOEP_OPEN_CBACK) (const UINT8 *p_name, UINT16 flags, UINT32 size, |
| UINT16 event_id, UINT8 app_id); |
| |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_CLOSE_CBACK |
| ** |
| ** Description This function is executed by OBX profiles when the file descriptor |
| ** is no longer in use. |
| ** |
| ** Returns void |
| ** |
| *******************************************************************************/ |
| typedef void (tGOEP_CLOSE_CBACK) (tGOEP_FD fd, UINT8 app_id); |
| |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_READ_CBACK |
| ** |
| ** Description This function is executed by OBX profiles to read in data from the |
| ** previously opened file. |
| ** |
| ** Returns void |
| ** |
| ** Note: Upon completion of the request, GOEP_ReadRsp() is |
| ** called with the buffer of data, along with the number |
| ** of bytes read into the buffer, and a status. The |
| ** call-in function should only be called when ALL requested |
| ** bytes have been read, the end of file has been detected, |
| ** or an error has occurred. |
| ** |
| *******************************************************************************/ |
| typedef void (tGOEP_READ_CBACK) (tGOEP_FD fd, void *p_data, INT16 size, |
| UINT16 event_id, UINT8 app_id); |
| |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_WRITE_CBACK |
| ** |
| ** Description This function is executed by OBX profiles to write the data to the |
| ** previously opened file. |
| ** |
| ** Returns void |
| ** |
| ** Note: Upon completion of the request, GOEP_WriteRsp() is |
| ** called with the file descriptor and the status. The |
| ** call-in function should only be called when ALL requested |
| ** bytes have been written, or an error has been detected, |
| ** |
| *******************************************************************************/ |
| typedef void (tGOEP_WRITE_CBACK) (tGOEP_FD fd, const void *p_data, INT16 size, |
| UINT16 event_id, UINT8 app_id); |
| |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_SEEK_CBACK |
| ** |
| ** Description This function is executed by OBX profiles to Move a file pointer |
| ** of a previously opened file to the specified location for the |
| ** next read or write operation. |
| ** |
| ** Returns void |
| ** |
| *******************************************************************************/ |
| typedef void (tGOEP_SEEK_CBACK) (tGOEP_FD fd, INT32 offset, INT16 origin, UINT8 app_id); |
| |
| |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_DIRENTRY_CBACK |
| ** |
| ** Description This function is called to retrieve a directory entry for the |
| ** specified path. The first/next directory should be filled |
| ** into the location specified by p_entry. |
| ** |
| ** Parameters p_path - directory to search (Fully qualified path) |
| ** first_item - TRUE if first search, FALSE if next search |
| ** (p_cur contains previous) |
| ** p_entry (input/output) - Points to last entry data (valid when |
| ** first_item is FALSE) |
| ** event_id - event that must be passed into the call-in function. |
| ** |
| ** Returns void |
| ** |
| ** Note: Upon completion of the request, GOEP_DirentryRsp() is |
| ** filled in entry and the status. |
| ** GOEP_OK is returned when p_entry is valid, |
| ** GOEP_EODIR is returned when no more entries [finished] |
| ** GOEP_FAIL is returned if an error occurred |
| ** |
| *******************************************************************************/ |
| typedef void (tGOEP_DIRENTRY_CBACK) (const char *p_path, BOOLEAN first_item, |
| tGOEP_DIRENTRY *p_entry, UINT16 event_id, |
| UINT8 app_id); |
| |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_ACCESS_CBACK |
| ** |
| ** Description This function is called to check the existence of a file or |
| ** directory. |
| ** |
| ** Returns (tGOEP_STATUS) status of the call. |
| ** [GOEP_OK if it exists] |
| ** [GOEP_EACCES if permissions are wrong] |
| ** [GOEP_FAIL if it does not exist] |
| ** |
| *******************************************************************************/ |
| typedef tGOEP_STATUS (tGOEP_ACCESS_CBACK) (const char *p_path, UINT16 mode, |
| BOOLEAN *p_is_dir, UINT8 app_id); |
| |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_MKDIR_CBACK |
| ** |
| ** Description This function is called to create a directory with |
| ** the pathname given by path. The pathname is a null terminated |
| ** string. All components of the path must already exist. |
| ** |
| ** Parameters p_path - (input) name of directory to create (fully qualified path). |
| ** |
| ** Returns (tGOEP_STATUS) status of the call. |
| ** [GOEP_OK if successful] |
| ** [GOEP_FAIL if unsuccessful] |
| ** |
| *******************************************************************************/ |
| typedef tGOEP_STATUS (tGOEP_MKDIR_CBACK) (const char *p_path, UINT8 app_id); |
| |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_RMDIR_CBACK |
| ** |
| ** Description This function is called to remove a directory whose |
| ** name is given by path. The directory must be empty. |
| ** |
| ** Parameters p_path - (input) name of directory to remove (fully qualified path). |
| ** |
| ** Returns (tGOEP_STATUS) status of the call. |
| ** [GOEP_OK if successful] |
| ** [GOEP_EACCES if read-only] |
| ** [GOEP_ENOTEMPTY if directory is not empty] |
| ** [GOEP_FAIL otherwise] |
| ** |
| *******************************************************************************/ |
| typedef tGOEP_STATUS (tGOEP_RMDIR_CBACK) (const char *p_path, UINT8 app_id); |
| |
| /******************************************************************************* |
| ** |
| ** Callback Function: tGOEP_UNLINK_CBACK |
| ** |
| ** Description This function is called to remove a directory whose |
| ** name is given by path. The directory must be empty. |
| ** |
| ** Parameters p_path - (input) name of file to remove (fully qualified path). |
| ** |
| ** Returns (tGOEP_STATUS) status of the call. |
| ** [GOEP_OK if successful] |
| ** [GOEP_EACCES if read-only] |
| ** [GOEP_FAIL otherwise] |
| ** |
| *******************************************************************************/ |
| typedef tGOEP_STATUS (tGOEP_UNLINK_CBACK) (const char *p_path, UINT8 app_id); |
| |
| |
| /***************************************************************************** |
| ** Prototypes |
| *****************************************************************************/ |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| /***************************************************************************** |
| ** |
| ** Function: GOEP_OpenRsp |
| ** |
| ** Purpose: Report the status of tGOEP_OPEN_CBACK callback function. |
| ** |
| ** Parameters: fd - File handle. |
| ** status - Status of the operation. |
| ** file_size - total number of bytes in this file. |
| ** event_id - event id as given in the tGOEP_OPEN_CBACK function. |
| ** |
| ** Returns: void |
| ** |
| *****************************************************************************/ |
| GOEP_API extern void GOEP_OpenRsp (tGOEP_FD fd, tGOEP_STATUS status, |
| UINT32 file_size, UINT16 event_id); |
| |
| /***************************************************************************** |
| ** |
| ** Function: GOEP_ReadRsp |
| ** |
| ** Purpose: Report the status of tGOEP_READ_CBACK callback function. |
| ** |
| ** Parameters: fd - File handle. |
| ** status - Status of the operation. |
| ** bytes_read - total number of bytes read from the file. |
| ** event_id - event id as given in the tGOEP_READ_CBACK function. |
| ** |
| ** Returns: void |
| ** |
| *****************************************************************************/ |
| GOEP_API extern void GOEP_ReadRsp (tGOEP_FD fd, tGOEP_STATUS status, |
| UINT16 bytes_read, UINT16 event_id); |
| |
| /***************************************************************************** |
| ** |
| ** Function: GOEP_WriteRsp |
| ** |
| ** Purpose: Report the status of tGOEP_WRITE_CBACK callback function. |
| ** |
| ** Parameters: fd - File handle. |
| ** status - Status of the operation. |
| ** event_id - event id as given in the tGOEP_WRITE_CBACK function. |
| ** |
| ** Returns: void |
| ** |
| *****************************************************************************/ |
| GOEP_API extern void GOEP_WriteRsp (tGOEP_FD fd, tGOEP_STATUS status, UINT16 event_id); |
| |
| /******************************************************************************* |
| ** |
| ** Function GOEP_DirentryRsp |
| ** |
| ** Description This function is called in response to the |
| ** tGOEP_DIRENTRY_CBACK function with a filled in directory listing |
| ** entry. |
| ** |
| ** Parameters status - GOEP_OK if p_entry points to a valid entry. |
| ** GOEP_EODIR if no more entries (p_entry is ignored). |
| ** GOEP_FAIL if any errors have occurred. |
| ** event_id - event id as given in the tGOEP_DIRENTRY_CBACK function. |
| ** |
| ** Returns void |
| ** |
| *******************************************************************************/ |
| GOEP_API extern void GOEP_DirentryRsp(tGOEP_STATUS status, UINT16 event_id); |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #endif /* GOEP_FS_H */ |