Files
Payload-SDK/psdk_lib/include/dji_platform.h

438 lines
16 KiB
C
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/**
********************************************************************
* @file dji_platform.h
* @brief This is the header file for "dji_platform.c", defining the structure and
* (exported) function prototypes.
*
* @copyright (c) 2021 DJI. All rights reserved.
*
* All information contained herein is, and remains, the property of DJI.
* The intellectual and technical concepts contained herein are proprietary
* to DJI and may be covered by U.S. and foreign patents, patents in process,
* and protected by trade secret or copyright law. Dissemination of this
* information, including but not limited to data and other proprietary
* material(s) incorporated within the information, in any form, is strictly
* prohibited without the express written consent of DJI.
*
* If you receive this source code without DJIs authorization, you may not
* further disseminate the information, and you must immediately remove the
* source code and notify DJI of its removal. DJI reserves the right to pursue
* legal actions against you for any loss(es) or damage(s) caused by your
* failure to do so.
*
*********************************************************************
*/
/* Define to prevent recursive inclusion -------------------------------------*/
#ifndef DJI_PLATFORM_H
#define DJI_PLATFORM_H
/* Includes ------------------------------------------------------------------*/
#include "dji_typedef.h"
#ifdef __cplusplus
extern "C" {
#endif
/* Exported constants --------------------------------------------------------*/
/* Exported types ------------------------------------------------------------*/
/**
* @brief Platform handle of uart operation.
*/
typedef void *T_DjiUartHandle;
/**
* @brief Platform handle of usb bulk operation.
*/
typedef void *T_DjiUsbBulkHandle;
/**
* @brief Platform handle of network operation.
*/
typedef void *T_DjiNetworkHandle;
/**
* @brief Platform handle of i2c device operation.
*/
typedef void *T_DjiI2cHandle;
/**
* @brief Platform handle of thread task operation.
*/
typedef void *T_DjiTaskHandle;
/**
* @brief Platform handle of mutex operation.
*/
typedef void *T_DjiMutexHandle;
/**
* @brief Platform handle of semaphore operation.
*/
typedef void *T_DjiSemaHandle;
/**
* @brief Platform handle of file operation.
*/
typedef void *T_DjiFileHandle;
/**
* @brief Platform handle of dir operation.
*/
typedef void *T_DjiDirHandle;
/**
* @brief Platform handle of socket operation.
*/
typedef void *T_DjiSocketHandle;
typedef enum {
/**
* All aircraft type supportusers can connect via chip serial port or USB to TTL serial port.
* Baud rate support list on M300 RTK Payload Port: 115200, 230400, 460800, 921600.
* Baud rate support list on M300 RTK Extension Port: 115200, 230400, 460800, 921600, 1000000.
* Baud rate support list on M30/M30T: 115200, 230400, 460800, 921600, 1000000.
* Baud rate support list on M3E/M3T: 921600.
* Baud rate support list on M350 RTK Payload Port: 115200, 230400, 460800, 921600.
* Baud rate support list on M350 RTK Extension Port: 115200, 230400, 460800, 921600, 1000000.
* */
DJI_HAL_UART_NUM_0,
/**
* Only support on M300/M350 RTK Extension Port by USB virtual serial port, such as /dev/ttyACM0.
* Baud rate support list on M300 RTK Extension Port: 921600.
* Baud rate support list on M350 RTK Extension Port: 921600.
* */
DJI_HAL_UART_NUM_1,
} E_DjiHalUartNum;
typedef enum {
DJI_HAL_USB_BULK_NUM_0 = 0,
DJI_HAL_USB_BULK_NUM_1,
DJI_HAL_USB_BULK_NUM_2,
DJI_HAL_USB_BULK_NUM_MAX,
} E_DjiHalUsbBulkNum;
typedef enum {
DJI_SOCKET_MODE_UDP,
DJI_SOCKET_MODE_TCP,
} E_DjiSocketMode;
typedef struct {
bool isConnect;
} T_DjiUartStatus;
typedef struct {
uint16_t year;
uint8_t month;
uint8_t day;
uint8_t hour;
uint8_t minute;
uint8_t second;
} T_DjiTime;
typedef struct {
uint32_t size;
T_DjiTime createTime;
T_DjiTime modifyTime;
char path[DJI_FILE_PATH_SIZE_MAX];
bool isDir;
} T_DjiFileInfo;
typedef struct {
uint16_t pid;
uint16_t vid;
} T_DjiHalUartDeviceInfo;
typedef struct {
T_DjiReturnCode (*UartInit)(E_DjiHalUartNum uartNum, uint32_t baudRate, T_DjiUartHandle *uartHandle);
T_DjiReturnCode (*UartDeInit)(T_DjiUartHandle uartHandle);
T_DjiReturnCode (*UartWriteData)(T_DjiUartHandle uartHandle, const uint8_t *buf, uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*UartReadData)(T_DjiUartHandle uartHandle, uint8_t *buf, uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*UartGetStatus)(E_DjiHalUartNum uartNum, T_DjiUartStatus *status);
/**
* Get the device info of USB uart (virtual com or TTL-To-USB) which directly connected to UAV.
* Use for SDK adapter type Eport V2 ribbon cable.
* When using other types of interface, it is not necessary to implement this member function.
*/
T_DjiReturnCode (*UartGetDeviceInfo)(T_DjiHalUartDeviceInfo *deviceInfo);
} T_DjiHalUartHandler;
typedef struct {
uint16_t interfaceNum;
uint16_t endPointIn;
uint16_t endPointOut;
} T_DjiHalUsbBulkChannelInfo;
typedef struct {
bool isUsbHost;
// attention: if 'isUsbHost' equals false, the following parameters is not valid.
uint16_t pid;
uint16_t vid;
T_DjiHalUsbBulkChannelInfo channelInfo;
} T_DjiHalUsbBulkInfo;
typedef struct {
uint16_t pid;
uint16_t vid;
T_DjiHalUsbBulkChannelInfo channelInfo[DJI_HAL_USB_BULK_NUM_MAX];
} T_DjiHalUsbBulkDeviceInfo;
typedef struct {
struct {
uint16_t vid;
uint16_t pid;
} usbNetAdapter;
} T_DjiHalNetworkDeviceInfo;
typedef struct {
uint32_t i2cSpeed;
uint16_t devAddress;
} T_DjiHalI2cConfig;
typedef struct {
T_DjiReturnCode (*UsbBulkInit)(T_DjiHalUsbBulkInfo usbBulkInfo, T_DjiUsbBulkHandle *usbBulkHandle);
T_DjiReturnCode (*UsbBulkDeInit)(T_DjiUsbBulkHandle usbBulkHandle);
T_DjiReturnCode (*UsbBulkWriteData)(T_DjiUsbBulkHandle usbBulkHandle, const uint8_t *buf,
uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*UsbBulkReadData)(T_DjiUsbBulkHandle usbBulkHandle, uint8_t *buf,
uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*UsbBulkGetDeviceInfo)(T_DjiHalUsbBulkDeviceInfo *deviceInfo);
} T_DjiHalUsbBulkHandler;
typedef struct {
T_DjiReturnCode (*NetworkInit)(const char *ipAddr, const char *netMask, T_DjiNetworkHandle *networkHandle);
T_DjiReturnCode (*NetworkDeInit)(T_DjiNetworkHandle networkHandle);
T_DjiReturnCode (*NetworkGetDeviceInfo)(T_DjiHalNetworkDeviceInfo *deviceInfo);
} T_DjiHalNetworkHandler;
typedef struct {
T_DjiReturnCode (*I2cInit)(T_DjiHalI2cConfig i2cConfig, T_DjiI2cHandle *i2cHandle);
T_DjiReturnCode (*I2cDeInit)(T_DjiI2cHandle i2cHandle);
T_DjiReturnCode (*I2cWriteData)(T_DjiI2cHandle i2cHandle, uint16_t devAddress, const uint8_t *buf,
uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*I2cReadData)(T_DjiI2cHandle i2cHandle, uint16_t devAddress, uint8_t *buf,
uint32_t len, uint32_t *realLen);
} T_DjiHalI2cHandler;
typedef struct {
T_DjiReturnCode (*TaskCreate)(const char *name, void *(*taskFunc)(void *),
uint32_t stackSize, void *arg, T_DjiTaskHandle *task);
T_DjiReturnCode (*TaskDestroy)(T_DjiTaskHandle task);
T_DjiReturnCode (*TaskSleepMs)(uint32_t timeMs);
T_DjiReturnCode (*MutexCreate)(T_DjiMutexHandle *mutex);
T_DjiReturnCode (*MutexDestroy)(T_DjiMutexHandle mutex);
T_DjiReturnCode (*MutexLock)(T_DjiMutexHandle mutex);
T_DjiReturnCode (*MutexUnlock)(T_DjiMutexHandle mutex);
T_DjiReturnCode (*SemaphoreCreate)(uint32_t initValue, T_DjiSemaHandle *semaphore);
T_DjiReturnCode (*SemaphoreDestroy)(T_DjiSemaHandle semaphore);
T_DjiReturnCode (*SemaphoreWait)(T_DjiSemaHandle semaphore);
T_DjiReturnCode (*SemaphoreTimedWait)(T_DjiSemaHandle semaphore, uint32_t waitTimeMs);
T_DjiReturnCode (*SemaphorePost)(T_DjiSemaHandle semaphore);
T_DjiReturnCode (*GetTimeMs)(uint32_t *ms);
T_DjiReturnCode (*GetTimeUs)(uint64_t *us);
T_DjiReturnCode (*GetRandomNum)(uint16_t *randomNum);
void *(*Malloc)(uint32_t size);
void (*Free)(void *ptr);
} T_DjiOsalHandler;
typedef struct {
T_DjiReturnCode (*FileOpen)(const char *fileName, const char *fileMode, T_DjiFileHandle *fileObj);
T_DjiReturnCode (*FileClose)(T_DjiFileHandle fileObj);
T_DjiReturnCode (*FileWrite)(T_DjiFileHandle fileObj, const uint8_t *buf, uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*FileRead)(T_DjiFileHandle fileObj, uint8_t *buf, uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*FileSeek)(T_DjiFileHandle fileObj, uint32_t offset);
T_DjiReturnCode (*FileSync)(T_DjiFileHandle fileObj);
T_DjiReturnCode (*DirOpen)(const char *filePath, T_DjiDirHandle *dirObj);
T_DjiReturnCode (*DirClose)(T_DjiDirHandle dirObj);
T_DjiReturnCode (*DirRead)(T_DjiDirHandle dirObj, T_DjiFileInfo *fileInfo);
T_DjiReturnCode (*Mkdir)(const char *filePath);
T_DjiReturnCode (*Unlink)(const char *filePath);
T_DjiReturnCode (*Rename)(const char *oldFilePath, const char *newFilePath);
T_DjiReturnCode (*Stat)(const char *filePath, T_DjiFileInfo *fileInfo);
} T_DjiFileSystemHandler;
typedef struct {
T_DjiReturnCode (*Socket)(E_DjiSocketMode mode, T_DjiSocketHandle *socketHandle);
T_DjiReturnCode (*Close)(T_DjiSocketHandle socketHandle);
T_DjiReturnCode (*Bind)(T_DjiSocketHandle socketHandle, const char *ipAddr, uint32_t port);
T_DjiReturnCode (*UdpSendData)(T_DjiSocketHandle socketHandle, const char *ipAddr, uint32_t port,
const uint8_t *buf, uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*UdpRecvData)(T_DjiSocketHandle socketHandle, char *ipAddr, uint32_t *port,
uint8_t *buf, uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*TcpListen)(T_DjiSocketHandle socketHandle);
T_DjiReturnCode (*TcpAccept)(T_DjiSocketHandle socketHandle, char *ipAddr, uint32_t *port,
T_DjiSocketHandle *outSocketHandle);
T_DjiReturnCode (*TcpConnect)(T_DjiSocketHandle socketHandle, const char *ipAddr, uint32_t port);
T_DjiReturnCode (*TcpSendData)(T_DjiSocketHandle socketHandle,
const uint8_t *buf, uint32_t len, uint32_t *realLen);
T_DjiReturnCode (*TcpRecvData)(T_DjiSocketHandle socketHandle,
uint8_t *buf, uint32_t len, uint32_t *realLen);
} T_DjiSocketHandler;
/* Exported functions --------------------------------------------------------*/
/**
* @brief Register the handler for hal uart interfaces by your platform.
* @note It should be noted that the interface in hal is written and tested well. Users need to implement all the
* interfaces. Otherwise, the user interface cannot be successfully registered, and then the user interface is registered
* through the interface. If the registration fails, it needs to be based on the return code. To judge the problem. Make
* sure that the feature is available after a successful registration. The interface needs to be called at the beginning of
* the application for registration, otherwise, the subsequent functions will not work properly.
* @param halUartHandler: pointer to the handler for hal uart interfaces by your platform.
* @return Execution result.
*/
T_DjiReturnCode DjiPlatform_RegHalUartHandler(const T_DjiHalUartHandler *halUartHandler);
/**
* @brief Register the handler for usb bulk interfaces by your platform.
* @param fileSystemHandler: pointer to the handler for usb bulk interfaces by your platform.
* @return Execution result.
*/
T_DjiReturnCode DjiPlatform_RegHalUsbBulkHandler(const T_DjiHalUsbBulkHandler *halUsbBulkHandler);
/**
* @brief Register the handler for hal network interfaces by your platform.
* @note It should be noted that the interface in hal is written and tested well. Users need to implement all the
* interfaces. Otherwise, the user interface cannot be successfully registered, and then the user interface is registered
* through the interface. If the registration fails, it needs to be based on the return code. To judge the problem. Make
* sure that the feature is available after a successful registration.
* @attention The interface needs to be called at the beginning of the application for registration, otherwise, the
* subsequent functions will not work properly.
* @param halNetworkHandler: pointer to the handler for network handler interfaces by your platform.
* @return Execution result.
*/
T_DjiReturnCode DjiPlatform_RegHalNetworkHandler(const T_DjiHalNetworkHandler *halNetworkHandler);
/**
* @brief Register the handler for hal i2c master mode interfaces by your platform.
* @note It should be noted that the interface in hal is written and tested well. Users need to implement all the
* interfaces. Otherwise, the user interface cannot be successfully registered, and then the user interface is registered
* through the interface. If the registration fails, it needs to be based on the return code. To judge the problem. Make
* sure that the feature is available after a successful registration.
* @attention The interface needs to be called at the beginning of the application for registration, otherwise, the
* subsequent functions will not work properly.
* @param halI2cHandler: pointer to the handler for hal i2c handler interfaces by your platform.
* @return Execution result.
*/
T_DjiReturnCode DjiPlatform_RegHalI2cHandler(const T_DjiHalI2cHandler *halI2cHandler);
/**
* @brief Register the handler for osal interfaces by your platform.
* @note It should be noted that the interface in osal is written and tested well. Users need to implement all the
* interfaces. Otherwise, the user interface cannot be successfully registered, and then the user interface is registered
* through the interface. If the registration fails, it needs to be based on the return code. To judge the problem. Make
* sure that the feature is available after a successful registration. The interface needs to be called at the beginning of
* the application for registration, otherwise, the subsequent functions will not work properly.
* @param osalHandler: pointer to the handler for osal interfaces by your platform.
* @return Execution result.
*/
T_DjiReturnCode DjiPlatform_RegOsalHandler(const T_DjiOsalHandler *osalHandler);
/**
* @brief Register the handler for file-system interfaces by your platform.
* @param fileSystemHandler: pointer to the handler for file-system interfaces by your platform.
* @return Execution result.
*/
T_DjiReturnCode DjiPlatform_RegFileSystemHandler(const T_DjiFileSystemHandler *fileSystemHandler);
/**
* @brief Register the handler for socket interfaces by your platform.
* @param fileSystemHandler: pointer to the handler for socket interfaces by your platform.
* @return Execution result.
*/
T_DjiReturnCode DjiPlatform_RegSocketHandler(const T_DjiSocketHandler *socketHandler);
/**
* @brief Get the handler of osal interfaces.
* @return Pointer to osal handler.
*/
T_DjiOsalHandler *DjiPlatform_GetOsalHandler(void);
/**
* @brief Get the handler of usb bulk interfaces.
* @return Pointer to usb bulk handler.
*/
T_DjiHalUsbBulkHandler *DjiPlatform_GetHalUsbBulkHandler(void);
/**
* @brief Get the handler of network interfaces.
* @return Pointer to network handler.
*/
T_DjiHalNetworkHandler *DjiPlatform_GetHalNetworkHandler(void);
/**
* @brief Get the handler of i2c interfaces.
* @return Pointer to i2c handler.
*/
T_DjiHalI2cHandler *DjiPlatform_GetHalI2cHandler(void);
/**
* @brief Get the handler of file-system interfaces.
* @return Pointer to file-system handler.
*/
T_DjiFileSystemHandler *DjiPlatform_GetFileSystemHandler(void);
/**
* @brief Get the handler of socket interfaces.
* @return Pointer to socket handler.
*/
T_DjiSocketHandler *DjiPlatform_GetSocketHandler(void);
#ifdef __cplusplus
}
#endif
#endif // DJI_PLATFORM_H
/************************ (C) COPYRIGHT DJI Innovations *******END OF FILE******/