/****************************************************************************** * * Copyright (C) 2003-2014 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. * ******************************************************************************/ /****************************************************************************** * * This is the interface file for the synchronization server call-out * functions. * ******************************************************************************/ #ifndef NFA_NV_CO_H #define NFA_NV_CO_H #include <time.h> #include "nfa_api.h" /***************************************************************************** ** Constants and Data Types *****************************************************************************/ /************************** ** Common Definitions ***************************/ /* Status codes returned by call-out functions, or in call-in functions as * status */ #define NFA_NV_CO_OK 0x00 #define NFA_NV_CO_FAIL 0x01 /* Used to pass all other errors */ #define NFA_NV_CO_EACCES 0x02 #define NFA_NV_CO_ENOTEMPTY 0x03 #define NFA_NV_CO_EOF 0x04 #define NFA_NV_CO_EODIR 0x05 #define NFA_NV_CO_ENOSPACE 0x06 /* Returned in nfa_nv_ci_open if no room */ #define NFA_NV_CO_EIS_DIR 0x07 #define NFA_NV_CO_RESUME 0x08 /* used in nfa_nv_ci_open, on resume */ /* used in nfa_nv_ci_open, on resume (no file to resume) */ #define NFA_NV_CO_NONE 0x09 typedef uint8_t tNFA_NV_CO_STATUS; #define DH_NV_BLOCK 0x01 #define HC_F3_NV_BLOCK 0x02 #define HC_F4_NV_BLOCK 0x03 #define HC_DH_NV_BLOCK 0x04 #define HC_F5_NV_BLOCK 0x05 /***************************************************************************** ** Function Declarations *****************************************************************************/ /************************** ** Common Functions ***************************/ /******************************************************************************* ** ** Function nfa_nv_co_read ** ** Description This function is called by NFA to read in data from the ** previously opened file. ** ** Parameters p_buf - buffer to read the data into. ** nbytes - number of bytes to read into the buffer. ** ** Returns void ** ** Note: Upon completion of the request, nfa_nv_ci_read () 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. ** *******************************************************************************/ extern void nfa_nv_co_read(uint8_t* p_buf, uint16_t nbytes, uint8_t block); /******************************************************************************* ** ** Function nfa_nv_co_write ** ** Description This function is called by io to send file data to the ** phone. ** ** Parameters p_buf - buffer to read the data from. ** nbytes - number of bytes to write out to the file. ** ** Returns void ** ** Note: Upon completion of the request, nfa_nv_ci_write () 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, ** *******************************************************************************/ extern void nfa_nv_co_write(const uint8_t* p_buf, uint16_t nbytes, uint8_t block); #endif /* NFA_NV_CO_H */