2022-08-06 23:25:58 +02:00
|
|
|
/*
|
2023-11-04 03:08:15 +01:00
|
|
|
* Copyright 2022-2023 NXP
|
2022-08-06 23:25:58 +02:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ZEPHYR_DRIVERS_SERIAL_UART_S32_LINFLEXD_H_
|
|
|
|
#define ZEPHYR_DRIVERS_SERIAL_UART_S32_LINFLEXD_H_
|
|
|
|
|
2022-12-27 15:17:35 +01:00
|
|
|
struct uart_nxp_s32_config {
|
2022-08-06 23:25:58 +02:00
|
|
|
uint32_t instance;
|
|
|
|
LINFLEXD_Type *base;
|
|
|
|
const struct pinctrl_dev_config *pincfg;
|
2023-11-04 03:08:15 +01:00
|
|
|
Linflexd_Uart_Ip_UserConfigType hw_cfg;
|
2022-08-06 23:25:58 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef CONFIG_UART_INTERRUPT_DRIVEN
|
2022-12-27 15:17:35 +01:00
|
|
|
struct uart_nxp_s32_int {
|
2022-08-06 23:25:58 +02:00
|
|
|
bool tx_fifo_busy;
|
|
|
|
bool rx_fifo_busy;
|
|
|
|
bool irq_tx_enable;
|
|
|
|
bool irq_rx_enable;
|
|
|
|
uint8_t rx_fifo_data;
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_UART_INTERRUPT_DRIVEN
|
2023-11-04 03:08:15 +01:00
|
|
|
struct uart_nxp_s32_data {
|
2022-12-27 15:17:35 +01:00
|
|
|
struct uart_nxp_s32_int int_data;
|
2022-08-06 23:25:58 +02:00
|
|
|
uart_irq_callback_user_data_t callback;
|
|
|
|
void *cb_data;
|
|
|
|
};
|
2023-11-04 03:08:15 +01:00
|
|
|
#endif /* CONFIG_UART_INTERRUPT_DRIVEN */
|
2022-08-06 23:25:58 +02:00
|
|
|
|
|
|
|
extern Linflexd_Uart_Ip_StateStructureType
|
|
|
|
Linflexd_Uart_Ip_apStateStructure[LINFLEXD_UART_IP_NUMBER_OF_INSTANCES];
|
|
|
|
|
|
|
|
#endif /* ZEPHYR_DRIVERS_SERIAL_UART_S32_LINFLEXD_H_ */
|