| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520 | 
							- /*******************************************************************************
 
- * Copyright 2011-2012, Cypress Semiconductor Corporation.  All rights reserved.
 
- * You may use this file only in accordance with the license, terms, conditions, 
 
- * disclaimers, and limitations in the end user license agreement accompanying 
 
- * the software package with which this file was provided.
 
- ********************************************************************************/
 
- #ifndef __CYBTLDR_COMMAND_H__
 
- #define __CYBTLDR_COMMAND_H__
 
- #include "cybtldr_utils.h"
 
- /* Maximum number of bytes to allocate for a single command.  */
 
- #define MAX_COMMAND_SIZE 512
 
- //STANDARD PACKET FORMAT:
 
- // Multi byte entries are encoded in LittleEndian.
 
- /*******************************************************************************
 
- * [1-byte] [1-byte ] [2-byte] [n-byte] [ 2-byte ] [1-byte]
 
- * [ SOP  ] [Command] [ Size ] [ Data ] [Checksum] [ EOP  ]
 
- *******************************************************************************/
 
- /* The first byte of any boot loader command. */
 
- #define CMD_START               0x01
 
- /* The last byte of any boot loader command. */
 
- #define CMD_STOP                0x17
 
- /* The minimum number of bytes in a bootloader command. */
 
- #define BASE_CMD_SIZE           0x07
 
- /* Command identifier for verifying the checksum value of the bootloadable project. */
 
- #define CMD_VERIFY_CHECKSUM     0x31
 
- /* Command identifier for getting the number of flash rows in the target device. */
 
- #define CMD_GET_FLASH_SIZE      0x32
 
- /* Command identifier for getting info about the app status. This is only supported on multi app bootloader. */
 
- #define CMD_GET_APP_STATUS      0x33
 
- /* Command identifier for reasing a row of flash data from the target device. */
 
- #define CMD_ERASE_ROW           0x34
 
- /* Command identifier for making sure the bootloader host and bootloader are in sync. */
 
- #define CMD_SYNC                0x35
 
- /* Command identifier for setting the active application. This is only supported on multi app bootloader. */
 
- #define CMD_SET_ACTIVE_APP      0x36
 
- /* Command identifier for sending a block of data to the bootloader without doing anything with it yet. */
 
- #define CMD_SEND_DATA           0x37
 
- /* Command identifier for starting the boot loader.  All other commands ignored until this is sent. */
 
- #define CMD_ENTER_BOOTLOADER    0x38
 
- /* Command identifier for programming a single row of flash. */
 
- #define CMD_PROGRAM_ROW         0x39
 
- /* Command identifier for verifying the contents of a single row of flash. */
 
- #define CMD_VERIFY_ROW          0x3A
 
- /* Command identifier for exiting the bootloader and restarting the target program. */
 
- #define CMD_EXIT_BOOTLOADER     0x3B
 
- /*
 
-  * This enum defines the different types of checksums that can be 
 
-  * used by the bootloader for ensuring data integrety.
 
-  */
 
- typedef enum
 
- {
 
-     /* Checksum type is a basic inverted summation of all bytes */
 
-     SUM_CHECKSUM = 0x00,
 
-     /* 16-bit CRC checksum using the CCITT implementation */
 
-     CRC_CHECKSUM = 0x01,
 
- } CyBtldr_ChecksumType;
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ComputeChecksum
 
- ********************************************************************************
 
- * Summary:
 
- *   Computes the 2byte checksum for the provided command data.  The checksum is 
 
- *   the 2's complement of the 1-byte sum of all bytes.
 
- *
 
- * Parameters:
 
- *   buf  - The data to compute the checksum on
 
- *   size - The number of bytes contained in buf.
 
- *
 
- * Returns:
 
- *   The checksum for the provided data.
 
- *
 
- *******************************************************************************/
 
- unsigned short CyBtldr_ComputeChecksum(unsigned char* buf, unsigned long size);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_SetCheckSumType
 
- ********************************************************************************
 
- * Summary:
 
- *   Updates what checksum algorithm is used when generating packets
 
- *
 
- * Parameters:
 
- *   chksumType - The type of checksum to use when creating packets
 
- *
 
- * Returns:
 
- *   NA
 
- *
 
- *******************************************************************************/
 
- void CyBtldr_SetCheckSumType(CyBtldr_ChecksumType chksumType);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseDefaultCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from any command that returns the default result packet
 
- *   data.  The default result is just a status byte
 
- *
 
- * Parameters:
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   status  - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- int CyBtldr_ParseDefaultCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned char* status);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateEnterBootLoaderCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to startup the bootloader.
 
- *   NB: This command must be sent before the bootloader will respond to any
 
- *       other command.
 
- *
 
- * Parameters:
 
- *   protect - The flash protection settings.
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateEnterBootLoaderCmd(unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseEnterBootLoaderCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from the EnterBootLoader command to get the resultant
 
- *   data.
 
- *
 
- * Parameters:
 
- *   cmdBuf     - The buffer containing the output from the bootloader.
 
- *   cmdSize    - The number of bytes in cmdBuf.
 
- *   siliconId  - The silicon ID of the device being communicated with.
 
- *   siliconRev - The silicon Revision of the device being communicated with.
 
- *   blVersion  - The bootloader version being communicated with.
 
- *   status     - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_ParseEnterBootLoaderCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned long* siliconId, unsigned char* siliconRev, unsigned long* blVersion, unsigned char* status);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateExitBootLoaderCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to stop communicating with the boot loader and to
 
- *   trigger the target device to restart, running the new bootloadable 
 
- *   application.
 
- *
 
- * Parameters:
 
- *   resetType - The type of reset to perform (0 = Reset, 1 = Direct Call).
 
- *   cmdBuf    - The preallocated buffer to store command data in.
 
- *   cmdSize   - The number of bytes in the command.
 
- *   resSize   - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateExitBootLoaderCmd(unsigned char resetType, unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateProgramRowCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to program a single flash row.
 
- *
 
- * Parameters:
 
- *   arrayId - The array id to program.
 
- *   rowNum  - The row number to program.
 
- *   buf     - The buffer of data to program into the flash row.
 
- *   size    - The number of bytes in data for the row.
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateProgramRowCmd(unsigned char arrayId, unsigned short rowNum, unsigned char* buf, unsigned short size, unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseProgramRowCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from the ProgramRow command to get the resultant
 
- *   data.
 
- *
 
- * Parameters:
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   status  - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_ParseProgramRowCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned char* status);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateVerifyRowCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to verify that the contents of flash match the
 
- *   provided row data.
 
- *
 
- * Parameters:
 
- *   arrayId - The array id to verify.
 
- *   rowNum  - The row number to verify.
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateVerifyRowCmd(unsigned char arrayId, unsigned short rowNum, unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseVerifyRowCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from the VerifyRow command to get the resultant
 
- *   data.
 
- *
 
- * Parameters:
 
- *   cmdBuf   - The preallocated buffer to store command data in.
 
- *   cmdSize  - The number of bytes in the command.
 
- *   checksum - The checksum from the row to verify.
 
- *   status   - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_ParseVerifyRowCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned char* checksum, unsigned char* status);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateEraseRowCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to erase a single flash row.
 
- *
 
- * Parameters:
 
- *   arrayId - The array id to erase.
 
- *   rowNum  - The row number to erase.
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateEraseRowCmd(unsigned char arrayId, unsigned short rowNum, unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseEraseRowCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from the EraseRow command to get the resultant
 
- *   data.
 
- *
 
- * Parameters:
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   status  - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_ParseEraseRowCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned char* status);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateVerifyChecksumCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to verify that the checkusm value in flash matches
 
- *   what is expected.
 
- *
 
- * Parameters:
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateVerifyChecksumCmd(unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseVerifyChecksumCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from the VerifyChecksum command to get the resultant
 
- *   data.
 
- *
 
- * Parameters:
 
- *   cmdBuf   - The preallocated buffer to store command data in.
 
- *   cmdSize  - The number of bytes in the command.
 
- *   checksumValid - Whether or not the full checksums match (1 = valid, 0 = invalid)
 
- *   status   - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_ParseVerifyChecksumCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned char* checksumValid, unsigned char* status);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateGetFlashSizeCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to retreive the number of flash rows in the device.
 
- *
 
- * Parameters:
 
- *   arrayId - The array ID to get the flash size of.
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateGetFlashSizeCmd(unsigned char arrayId, unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseGetFlashSizeCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from the GetFlashSize command to get the resultant
 
- *   data.
 
- *
 
- * Parameters:
 
- *   cmdBuf   - The preallocated buffer to store command data in.
 
- *   cmdSize  - The number of bytes in the command.
 
- *   startRow - The first available row number in the flash array.
 
- *   endRow   - The last available row number in the flash array.
 
- *   status   - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_ParseGetFlashSizeCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned short* startRow, unsigned short* endRow, unsigned char* status);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateSendDataCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to send a block of data to the target.
 
- *
 
- * Parameters:
 
- *   buf     - The buffer of data data to program into the flash row.
 
- *   size    - The number of bytes in data for the row.
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateSendDataCmd(unsigned char* buf, unsigned short size, unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseSendDataCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from the SendData command to get the resultant
 
- *   data.
 
- *
 
- * Parameters:
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   status  - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_ParseSendDataCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned char* status);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateSyncBootLoaderCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to ensure that the host application is in sync
 
- *   with the bootloader application.
 
- *
 
- * Parameters:
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateSyncBootLoaderCmd(unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateGetAppStatusCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to get information about the application.  This
 
- *   command is only supported by the multi application bootloaader.
 
- *
 
- * Parameters:
 
- *   appId   - The id for the application to get status for
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateGetAppStatusCmd(unsigned char appId, unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseGetAppStatusCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from the GetAppStatus command to get the resultant
 
- *   data.
 
- *
 
- * Parameters:
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   isValid - Is the application valid.
 
- *   isActive- Is the application currently marked as active.
 
- *   status  - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_ParseGetAppStatusCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned char* isValid, unsigned char* isActive, unsigned char* status);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_CreateSetActiveAppCmd
 
- ********************************************************************************
 
- * Summary:
 
- *   Creates the command used to set the active application for the bootloader 
 
- *   to run.  This command is only supported by the multi application 
 
- *   bootloaader.
 
- *
 
- * Parameters:
 
- *   appId   - The id for the application to get status for
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   resSize - The number of bytes expected in the bootloader's response packet.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS  - The command was constructed successfully
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_CreateSetActiveAppCmd(unsigned char appId, unsigned char* cmdBuf, unsigned long* cmdSize, unsigned long* resSize);
 
- /*******************************************************************************
 
- * Function Name: CyBtldr_ParseSetActiveAppCmdResult
 
- ********************************************************************************
 
- * Summary:
 
- *   Parses the output from the SetActiveApp command to get the resultant
 
- *   data.
 
- *
 
- * Parameters:
 
- *   cmdBuf  - The preallocated buffer to store command data in.
 
- *   cmdSize - The number of bytes in the command.
 
- *   status  - The status code returned by the bootloader.
 
- *
 
- * Returns:
 
- *   CYRET_SUCCESS    - The command was constructed successfully
 
- *   CYRET_ERR_LENGTH - The packet does not contain enough data
 
- *   CYRET_ERR_DATA   - The packet's contents are not correct
 
- *
 
- *******************************************************************************/
 
- EXTERN int CyBtldr_ParseSetActiveAppCmdResult(unsigned char* cmdBuf, unsigned long cmdSize, unsigned char* status);
 
- #endif
 
 
  |