/*
* Copyright (C) 2016 The Android Open Source Project
*
* 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 __NANOHUBPACKET_H
#define __NANOHUBPACKET_H
/**
* Formats and constants related to nanohub packets. This header is intended
* to be shared between the host Linux kernel and the nanohub implementation.
*/
#include "toolchain.h"
#ifdef __KERNEL__
#include <linux/types.h>
#else
#include <hostIntf.h>
#include <stdint.h>
typedef uint16_t __le16;
typedef uint16_t __be16;
typedef uint32_t __le32;
typedef uint32_t __be32;
typedef uint64_t __le64;
typedef uint64_t __be64;
#endif
SET_PACKED_STRUCT_MODE_ON
struct NanohubPacket {
uint8_t sync;
__le32 seq;
__le32 reason;
uint8_t len;
uint8_t data[0];
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubPacketFooter {
__le32 crc;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
static inline struct NanohubPacketFooter *nanohubGetPacketFooter(struct NanohubPacket *packet)
{
return (struct NanohubPacketFooter *)(packet->data + packet->len);
}
#define NANOHUB_PACKET_SIZE(len) \
(sizeof(struct NanohubPacket) + (len) + sizeof(struct NanohubPacketFooter))
#define NANOHUB_PACKET_PAYLOAD_MAX 255
#define NANOHUB_PACKET_SIZE_MAX NANOHUB_PACKET_SIZE(NANOHUB_PACKET_PAYLOAD_MAX)
#define NANOHUB_SYNC_BYTE 0x31
#define NANOHUB_PREAMBLE_BYTE 0xFF
#define NANOHUB_ACK_PREAMBLE_LEN 16
#define NANOHUB_PAYLOAD_PREAMBLE_LEN 512
#define NANOHUB_RSA_KEY_CHUNK_LEN 64
#define NANOHUB_INT_BOOT_COMPLETE 0
#define NANOHUB_INT_WAKE_COMPLETE 0
#define NANOHUB_INT_WAKEUP 1
#define NANOHUB_INT_NONWAKEUP 2
#define NANOHUB_INT_CMD_WAIT 3
#define NANOHUB_REASON_ACK 0x00000000
#define NANOHUB_REASON_NAK 0x00000001
#define NANOHUB_REASON_NAK_BUSY 0x00000002
/**
* INFORMATIONAL
*/
#define NANOHUB_REASON_GET_OS_HW_VERSIONS 0x00001000
#if defined(__GNUC__)
SET_PACKED_STRUCT_MODE_ON
struct NanohubOsHwVersionsRequest {
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#endif
SET_PACKED_STRUCT_MODE_ON
struct NanohubOsHwVersionsResponse {
__le16 hwType;
__le16 hwVer;
__le16 blVer;
__le16 osVer;
__le32 variantVer;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_GET_APP_VERSIONS 0x00001001
SET_PACKED_STRUCT_MODE_ON
struct NanohubAppVersionsRequest {
__le64 appId;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubAppVersionsResponse {
__le32 appVer;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_QUERY_APP_INFO 0x00001002
SET_PACKED_STRUCT_MODE_ON
struct NanohubAppInfoRequest {
__le32 appIdx;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubAppInfoResponse {
__le64 appId;
__le32 appVer;
__le32 appSize;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_START_FIRMWARE_UPLOAD 0x00001040
SET_PACKED_STRUCT_MODE_ON
struct NanohubStartFirmwareUploadRequest {
__le32 size;
__le32 crc;
uint8_t type;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubStartFirmwareUploadResponse {
uint8_t accepted;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_FIRMWARE_CHUNK 0x00001041
SET_PACKED_STRUCT_MODE_ON
struct NanohubFirmwareChunkRequest {
__le32 offset;
uint8_t data[NANOHUB_PACKET_PAYLOAD_MAX-sizeof(__le32)];
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
enum NanohubFirmwareChunkReply {
NANOHUB_FIRMWARE_CHUNK_REPLY_ACCEPTED = 0,
NANOHUB_FIRMWARE_CHUNK_REPLY_WAIT,
NANOHUB_FIRMWARE_CHUNK_REPLY_RESEND,
NANOHUB_FIRMWARE_CHUNK_REPLY_RESTART,
NANOHUB_FIRMWARE_CHUNK_REPLY_CANCEL,
NANOHUB_FIRMWARE_CHUNK_REPLY_CANCEL_NO_RETRY,
};
SET_PACKED_STRUCT_MODE_ON
struct NanohubFirmwareChunkResponse {
uint8_t chunkReply;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_FINISH_FIRMWARE_UPLOAD 0x00001042
#if defined(__GNUC__)
SET_PACKED_STRUCT_MODE_ON
struct NanohubFinishFirmwareUploadRequest {
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#endif
enum NanohubFirmwareUploadReply {
NANOHUB_FIRMWARE_UPLOAD_SUCCESS = 0,
NANOHUB_FIRMWARE_UPLOAD_PROCESSING,
NANOHUB_FIRMWARE_UPLOAD_WAITING_FOR_DATA,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_KEY_NOT_FOUND,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_HEADER_ERROR,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_TOO_MUCH_DATA,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_TOO_LITTLE_DATA,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_SIG_VERIFY_FAIL,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_SIG_DECODE_FAIL,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_SIG_ROOT_UNKNOWN,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_MEMORY_ERROR,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_INVALID_DATA,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_VERIFY_FAILED,
NANOHUB_FIRMWARE_UPLOAD_APP_SEC_BAD,
};
SET_PACKED_STRUCT_MODE_ON
struct NanohubFinishFirmwareUploadResponse {
uint8_t uploadReply;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_GET_INTERRUPT 0x00001080
SET_PACKED_STRUCT_MODE_ON
struct NanohubGetInterruptRequest {
uint32_t clear[HOSTINTF_MAX_INTERRUPTS/(32*sizeof(uint8_t))];
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubGetInterruptResponse {
uint32_t interrupts[HOSTINTF_MAX_INTERRUPTS/(32*sizeof(uint8_t))];
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_MASK_INTERRUPT 0x00001081
SET_PACKED_STRUCT_MODE_ON
struct NanohubMaskInterruptRequest {
uint8_t interrupt;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubMaskInterruptResponse {
uint8_t accepted;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_UNMASK_INTERRUPT 0x00001082
SET_PACKED_STRUCT_MODE_ON
struct NanohubUnmaskInterruptRequest {
uint8_t interrupt;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubUnmaskInterruptResponse {
uint8_t accepted;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_READ_EVENT 0x00001090
SET_PACKED_STRUCT_MODE_ON
struct NanohubReadEventRequest {
__le64 apBootTime;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubReadEventResponse {
__le32 evtType;
uint8_t evtData[NANOHUB_PACKET_PAYLOAD_MAX - sizeof(__le32)];
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_REASON_WRITE_EVENT 0x00001091
SET_PACKED_STRUCT_MODE_ON
struct NanohubWriteEventRequest {
__le32 evtType;
uint8_t evtData[NANOHUB_PACKET_PAYLOAD_MAX - sizeof(__le32)];
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubWriteEventResponse {
uint8_t accepted;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalHdr {
uint64_t appId;
uint8_t len;
uint8_t msg;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_HAL_EXT_APPS_ON 0
#define NANOHUB_HAL_EXT_APPS_OFF 1
#define NANOHUB_HAL_EXT_APP_DELETE 2
// this behaves more stable w.r.t. endianness than bit field
// this is setting byte fields in MgmtStatus response
// the high-order bit, if set, is indication of counter overflow
#define SET_COUNTER(counter, val) (counter = (val & 0x7F) | (val > 0x7F ? 0x80 : 0))
SET_PACKED_STRUCT_MODE_ON
struct MgmtStatus {
union {
__le32 value;
// NOTE: union fields are accessed in CPU native mode
struct {
uint8_t app;
uint8_t task;
uint8_t op;
uint8_t erase;
} ATTRIBUTE_PACKED;
};
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalMgmtRx {
__le64 appId;
struct MgmtStatus stat;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalMgmtTx {
struct NanohubHalHdr hdr;
__le32 status;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_HAL_QUERY_MEMINFO 3
#define NANOHUB_HAL_QUERY_APPS 4
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalQueryAppsRx {
__le32 idx;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalQueryAppsTx {
struct NanohubHalHdr hdr;
__le64 appId;
__le32 version;
__le32 flashUse;
__le32 ramUse;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_HAL_QUERY_RSA_KEYS 5
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalQueryRsaKeysRx {
__le32 offset;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalQueryRsaKeysTx {
struct NanohubHalHdr hdr;
uint8_t data[];
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_HAL_START_UPLOAD 6
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalStartUploadRx {
uint8_t isOs;
__le32 length;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalStartUploadTx {
struct NanohubHalHdr hdr;
uint8_t success;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_HAL_CONT_UPLOAD 7
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalContUploadRx {
__le32 offset;
uint8_t data[];
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalContUploadTx {
struct NanohubHalHdr hdr;
uint8_t success;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_HAL_FINISH_UPLOAD 8
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalFinishUploadTx {
struct NanohubHalHdr hdr;
uint8_t success;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#define NANOHUB_HAL_REBOOT 9
SET_PACKED_STRUCT_MODE_ON
struct NanohubHalRebootTx {
struct NanohubHalHdr hdr;
__le32 reason;
} ATTRIBUTE_PACKED;
SET_PACKED_STRUCT_MODE_OFF
#endif /* __NANOHUBPACKET_H */