pinebuds/platform/hal/hal_transq.h

93 lines
2.7 KiB
C
Raw Permalink Normal View History

2022-08-15 04:20:27 -05:00
/***************************************************************************
*
* Copyright 2015-2019 BES.
* All rights reserved. All unpublished rights reserved.
*
* No part of this work may be used or reproduced in any form or by any
* means, or stored in a database or retrieval system, without prior written
* permission of BES.
*
* Use of this work is governed by a license granted by BES.
* This work contains confidential and proprietary information of
* BES. which is protected by copyright, trade secret,
* trademark and other intellectual property rights.
*
****************************************************************************/
#ifndef __HAL_TRANSQ_H__
#define __HAL_TRANSQ_H__
#ifdef __cplusplus
extern "C" {
#endif
#ifdef CHIP_HAS_TRANSQ
#include "plat_types.h"
enum HAL_TRANSQ_ID_T {
HAL_TRANSQ_ID_0 = 0,
#if (CHIP_HAS_TRANSQ > 1)
HAL_TRANSQ_ID_1,
#endif
HAL_TRANSQ_ID_QTY
};
enum HAL_TRANSQ_PRI_T {
HAL_TRANSQ_PRI_NORMAL = 0,
HAL_TRANSQ_PRI_HIGH,
HAL_TRANSQ_PRI_QTY
};
enum HAL_TRANSQ_RET_T {
HAL_TRANSQ_RET_OK = 0,
HAL_TRANSQ_RET_BAD_ID,
HAL_TRANSQ_RET_BAD_PRI,
HAL_TRANSQ_RET_BAD_CFG,
HAL_TRANSQ_RET_BAD_SLOT,
HAL_TRANSQ_RET_BAD_TX_NUM,
HAL_TRANSQ_RET_BAD_RX_NUM,
HAL_TRANSQ_RET_BAD_MODE,
HAL_TRANSQ_RET_RX_EMPTY,
HAL_TRANSQ_RET_TX_FULL,
};
typedef void (*HAL_TRANSQ_RX_IRQ_HANDLER)(enum HAL_TRANSQ_PRI_T pri);
typedef void (*HAL_TRANSQ_TX_IRQ_HANDLER)(enum HAL_TRANSQ_PRI_T pri, const uint8_t *data, uint32_t len);
struct HAL_TRANSQ_SLOT_NUM_T {
uint8_t tx_num[HAL_TRANSQ_PRI_QTY];
uint8_t rx_num[HAL_TRANSQ_PRI_QTY];
};
struct HAL_TRANSQ_CFG_T {
struct HAL_TRANSQ_SLOT_NUM_T slot;
HAL_TRANSQ_RX_IRQ_HANDLER rx_handler;
HAL_TRANSQ_TX_IRQ_HANDLER tx_handler;
};
enum HAL_TRANSQ_RET_T hal_transq_get_rx_status(enum HAL_TRANSQ_ID_T id, enum HAL_TRANSQ_PRI_T pri, bool *ready);
enum HAL_TRANSQ_RET_T hal_transq_get_tx_status(enum HAL_TRANSQ_ID_T id, enum HAL_TRANSQ_PRI_T pri, bool *done);
enum HAL_TRANSQ_RET_T hal_transq_rx_first(enum HAL_TRANSQ_ID_T id, enum HAL_TRANSQ_PRI_T pri, const uint8_t **data, uint32_t *len);
enum HAL_TRANSQ_RET_T hal_transq_rx_next(enum HAL_TRANSQ_ID_T id, enum HAL_TRANSQ_PRI_T pri, const uint8_t **data, uint32_t *len);
enum HAL_TRANSQ_RET_T hal_transq_tx(enum HAL_TRANSQ_ID_T id, enum HAL_TRANSQ_PRI_T pri, const uint8_t *data, uint32_t len);
enum HAL_TRANSQ_RET_T hal_transq_update_num(enum HAL_TRANSQ_ID_T id, const struct HAL_TRANSQ_SLOT_NUM_T *slot);
enum HAL_TRANSQ_RET_T hal_transq_open(enum HAL_TRANSQ_ID_T id, const struct HAL_TRANSQ_CFG_T *cfg);
enum HAL_TRANSQ_RET_T hal_transq_close(enum HAL_TRANSQ_ID_T id);
#endif // CHIP_HAS_TRANSQ
#ifdef __cplusplus
}
#endif
#endif