forked from xuos/xiuos
				
			add hal ethernet driver
This commit is contained in:
		
							parent
							
								
									5d6cd493bf
								
							
						
					
					
						commit
						4f182f90c9
					
				| 
						 | 
					@ -43,7 +43,7 @@ INC_DIR = 	-I$(KERNEL_ROOT)/services/shell/letter-shell \
 | 
				
			||||||
			-I$(KERNEL_ROOT)/services/app 
 | 
								-I$(KERNEL_ROOT)/services/app 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifeq ($(BOARD), imx6q-sabrelite)
 | 
					ifeq ($(BOARD), imx6q-sabrelite)
 | 
				
			||||||
all: init test_fault simple_client simple_server shell fs_server semaphore_server test_semaphore test_ipc_null test_thread test_irq_hdlr test_irq_block test_irq_send eth_driver epit_server test_net lwip readme.txt | bin
 | 
					all: init test_fault simple_client simple_server shell fs_server semaphore_server test_semaphore test_ipc_null test_thread test_irq_hdlr test_irq_block test_irq_send eth_driver epit_server test_net lwip ethernet readme.txt | bin
 | 
				
			||||||
else 
 | 
					else 
 | 
				
			||||||
all: init test_fault simple_client simple_server shell fs_server semaphore_server test_ipc_null test_thread test_semaphore readme.txt | bin
 | 
					all: init test_fault simple_client simple_server shell fs_server semaphore_server test_ipc_null test_thread test_semaphore readme.txt | bin
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
| 
						 | 
					@ -64,6 +64,10 @@ eth_driver: enet_drv.o enet_test.o board_network.o enet_iomux_config.o imx6dq_gp
 | 
				
			||||||
	@${ld} ${user_ldflags} -e main -o $@ $^ ${board_specs}
 | 
						@${ld} ${user_ldflags} -e main -o $@ $^ ${board_specs}
 | 
				
			||||||
	@${objdump} -S $@ > $@.asm
 | 
						@${objdump} -S $@ > $@.asm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ethernet: test_gmac.o gmac.o gmac_3568.o hal_base.o hal_bsp.o hal_pinctrl_v2.o hal_cru.o hal_cache.o hal_gpio.o hal_timer.o hal_cru_rk3568.o libserial.o printf.o libmem.o usyscall.o arch_usyscall.o session.o libipc.o 
 | 
				
			||||||
 | 
						@${ld} ${user_ldflags} -e main -o $@ $^ ${board_specs}
 | 
				
			||||||
 | 
						@${objdump} -S $@ > $@.asm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
epit_server: timer.o epit.o ccm_pll.o usyscall.o arch_usyscall.o libserial.o printf.o libipc.o session.o
 | 
					epit_server: timer.o epit.o ccm_pll.o usyscall.o arch_usyscall.o libserial.o printf.o libipc.o session.o
 | 
				
			||||||
	@${ld} ${user_ldflags} -e main -o $@ $^ ${board_specs}
 | 
						@${ld} ${user_ldflags} -e main -o $@ $^ ${board_specs}
 | 
				
			||||||
	@${objdump} -S $@ > $@.asm
 | 
						@${objdump} -S $@ > $@.asm
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,4 +1,4 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
SRC_DIR :=  $(BOARD)
 | 
					SRC_DIR :=  $(BOARD) rk-3568
 | 
				
			||||||
 | 
					
 | 
				
			||||||
include $(KERNEL_ROOT)/compiler.mk
 | 
					include $(KERNEL_ROOT)/compiler.mk
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,4 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRC_DIR := ethernet
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					include $(KERNEL_ROOT)/compiler.mk
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,37 @@
 | 
				
			||||||
 | 
					ifeq ($(BOARD), imx6q-sabrelite)
 | 
				
			||||||
 | 
					toolchain ?= arm-none-eabi-
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					ifeq ($(BOARD), zynq7000-zc702)
 | 
				
			||||||
 | 
					toolchain ?= arm-xilinx-eabi-
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					cc = ${toolchain}gcc
 | 
				
			||||||
 | 
					ld = ${toolchain}g++
 | 
				
			||||||
 | 
					objdump = ${toolchain}objdump
 | 
				
			||||||
 | 
					user_ldflags = -N -Ttext 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					cflags = -std=c11  -g \
 | 
				
			||||||
 | 
						-Wno-unused -Wno-format -fno-common -ffreestanding -fno-builtin -static \
 | 
				
			||||||
 | 
						-Wno-unaligned-access -fdce -Wall -Werror -Wno-uninitialized -Wno-strict-aliasing -fdiagnostics-show-option \
 | 
				
			||||||
 | 
						-mapcs -marm -mfpu=neon -ftree-vectorize -fno-math-errno -funsafe-math-optimizations -fno-signed-zeros -mfloat-abi=softfp \
 | 
				
			||||||
 | 
						-fno-omit-frame-pointer -fno-stack-protector -fno-pie 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# cflags = -std=c11 -march=armv7-a -mtune=cortex-a9 -nostdlib -nodefaultlibs -mfloat-abi=soft -fno-pic \
 | 
				
			||||||
 | 
					# 	-static -fno-builtin -fno-strict-aliasing -Wall -ggdb -Wno-unused -Werror -fno-omit-frame-pointer -fno-stack-protector -fno-pie 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					c_useropts = -O0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					INC_DIR = 	-I$(KERNEL_ROOT)/services/app \
 | 
				
			||||||
 | 
							  	-I$(KERNEL_ROOT)/services/boards/$(BOARD) \
 | 
				
			||||||
 | 
								-I$(KERNEL_ROOT)/services/lib/serial \
 | 
				
			||||||
 | 
								-I$(KERNEL_ROOT)/services/drivers/rk-3568/include \
 | 
				
			||||||
 | 
								-I$(KERNEL_ROOT)/services/lib/usyscall \
 | 
				
			||||||
 | 
							  	-I$(KERNEL_ROOT)/services/lib/ipc \
 | 
				
			||||||
 | 
							  	-I$(KERNEL_ROOT)/services/lib/memory 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					all: gmac.o gmac_3568.o test_gmac.o hal_base.o hal_bsp.o hal_pinctrl_v2.o hal_cru.o hal_cache.o hal_gpio.o hal_timer.o hal_cru_rk3568.o
 | 
				
			||||||
 | 
						@mv $^ $(KERNEL_ROOT)/services/app
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					%.o: %.c
 | 
				
			||||||
 | 
						@echo "cc $^"
 | 
				
			||||||
 | 
						@${cc} ${cflags} ${c_useropts} ${INC_DIR} -o $@ -c $^
 | 
				
			||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| 
						 | 
					@ -0,0 +1,199 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_base.h"
 | 
				
			||||||
 | 
					#include "hal_gmac.h"
 | 
				
			||||||
 | 
					#include "hal_debug.h"
 | 
				
			||||||
 | 
					#include "hal_cru.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup GMAC
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup GMAC_Private_Definition Private Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/********************* Private MACRO Definition ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HIWORD_UPDATE(val, mask, shift) \
 | 
				
			||||||
 | 
					        ((val) << (shift) | (mask) << ((shift) + 16))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GRF_BIT(nr)     (1 << (nr) | 1 << (nr+16))
 | 
				
			||||||
 | 
					#define GRF_CLR_BIT(nr) (1 << (nr+16))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define DELAY_ENABLE(soc, tx, rx)                                          \
 | 
				
			||||||
 | 
					    (((tx) ? soc##_GMAC_TXCLK_DLY_ENABLE : soc##_GMAC_TXCLK_DLY_DISABLE) | \
 | 
				
			||||||
 | 
					     ((rx) ? soc##_GMAC_RXCLK_DLY_ENABLE : soc##_GMAC_RXCLK_DLY_DISABLE))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define RK3568_GRF_GMAC0_CON0 0X0380
 | 
				
			||||||
 | 
					#define RK3568_GRF_GMAC0_CON1 0X0384
 | 
				
			||||||
 | 
					#define RK3568_GRF_GMAC1_CON0 0X0388
 | 
				
			||||||
 | 
					#define RK3568_GRF_GMAC1_CON1 0X038c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* RK3568_GRF_GMAC0_CON1 && RK3568_GRF_GMAC1_CON1 */
 | 
				
			||||||
 | 
					#define RK3568_GMAC_GMII_MODE GRF_BIT(7)
 | 
				
			||||||
 | 
					#define RK3568_GMAC_PHY_INTF_SEL_RGMII \
 | 
				
			||||||
 | 
					        (GRF_BIT(4) | GRF_CLR_BIT(5) | GRF_CLR_BIT(6))
 | 
				
			||||||
 | 
					#define RK3568_GMAC_PHY_INTF_SEL_RMII \
 | 
				
			||||||
 | 
					        (GRF_CLR_BIT(4) | GRF_CLR_BIT(5) | GRF_BIT(6))
 | 
				
			||||||
 | 
					#define RK3568_GMAC_FLOW_CTRL         GRF_BIT(3)
 | 
				
			||||||
 | 
					#define RK3568_GMAC_FLOW_CTRL_CLR     GRF_CLR_BIT(3)
 | 
				
			||||||
 | 
					#define RK3568_GMAC_RXCLK_DLY_ENABLE  GRF_BIT(1)
 | 
				
			||||||
 | 
					#define RK3568_GMAC_RXCLK_DLY_DISABLE GRF_CLR_BIT(1)
 | 
				
			||||||
 | 
					#define RK3568_GMAC_TXCLK_DLY_ENABLE  GRF_BIT(0)
 | 
				
			||||||
 | 
					#define RK3568_GMAC_TXCLK_DLY_DISABLE GRF_CLR_BIT(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* RK3568_GRF_GMAC0_CON0 && RK3568_GRF_GMAC1_CON0 */
 | 
				
			||||||
 | 
					#define RK3568_GMAC_CLK_RX_DL_CFG(val) HIWORD_UPDATE(val, 0x7F, 8)
 | 
				
			||||||
 | 
					#define RK3568_GMAC_CLK_TX_DL_CFG(val) HIWORD_UPDATE(val, 0x7F, 0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Variable Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Function Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/********************* Public Function Definition ****************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup GMAC_Exported_Functions_Group5 Other Functions
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set RGMII Mode.
 | 
				
			||||||
 | 
					 * @param  pGMAC: pointer to a GMAC_HANDLE structure that contains
 | 
				
			||||||
 | 
					 *                the information for GMAC module.
 | 
				
			||||||
 | 
					 * @param  txDelay: RGMII tx delayline
 | 
				
			||||||
 | 
					 * @param  rxDelay: RGMII rx delayline
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_GMAC_SetToRGMII(struct GMAC_HANDLE *pGMAC,
 | 
				
			||||||
 | 
					                         int32_t txDelay, int32_t rxDelay)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t *con0, *con1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    con0 = (uint32_t *)((pGMAC->pReg == GMAC1) ? &(GRF->MAC1_CON0) :
 | 
				
			||||||
 | 
					                                                 &(GRF->MAC0_CON0));
 | 
				
			||||||
 | 
					    con1 = (uint32_t *)((pGMAC->pReg == GMAC1) ? &(GRF->MAC1_CON1) :
 | 
				
			||||||
 | 
					                                                 &(GRF->MAC0_CON1));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    WRITE_REG(*con1,
 | 
				
			||||||
 | 
					              RK3568_GMAC_PHY_INTF_SEL_RGMII |
 | 
				
			||||||
 | 
					              RK3568_GMAC_RXCLK_DLY_ENABLE |
 | 
				
			||||||
 | 
					              RK3568_GMAC_TXCLK_DLY_ENABLE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    WRITE_REG(*con0,
 | 
				
			||||||
 | 
					              RK3568_GMAC_CLK_RX_DL_CFG(rxDelay) |
 | 
				
			||||||
 | 
					              RK3568_GMAC_CLK_TX_DL_CFG(txDelay));
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set RMII Mode.
 | 
				
			||||||
 | 
					 * @param  pGMAC: pointer to a GMAC_HANDLE structure that contains
 | 
				
			||||||
 | 
					 *                the information for GMAC module.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_GMAC_SetToRMII(struct GMAC_HANDLE *pGMAC)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t *con1, *cruCon, val;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    con1 = (uint32_t *)((pGMAC->pReg == GMAC1) ? &(GRF->MAC1_CON1) :
 | 
				
			||||||
 | 
					                                                 &(GRF->MAC0_CON1));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    WRITE_REG(*con1, RK3568_GMAC_PHY_INTF_SEL_RMII);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    cruCon = (uint32_t *)((pGMAC->pReg == GMAC1) ? &(CRU->CRU_CLKSEL_CON[33]) :
 | 
				
			||||||
 | 
					                                                   &(CRU->CRU_CLKSEL_CON[31]));
 | 
				
			||||||
 | 
					    /* RMII mode */
 | 
				
			||||||
 | 
					    val = HIWORD_UPDATE(0x1, 0x3, 0);
 | 
				
			||||||
 | 
					    /* clock from io if it was */
 | 
				
			||||||
 | 
					    /* val |= HIWORD_UPDATE(0x1, 0x1, 2);  */
 | 
				
			||||||
 | 
					    /* ref clock sel 50M */
 | 
				
			||||||
 | 
					    val |= HIWORD_UPDATE(0x1, 0x3, 8);
 | 
				
			||||||
 | 
					    /* clock speed 25M */
 | 
				
			||||||
 | 
					    val |= HIWORD_UPDATE(0x1, 0x1, 3);
 | 
				
			||||||
 | 
					    WRITE_REG(*cruCon, val);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set external clock source select.
 | 
				
			||||||
 | 
					 * @param  pGMAC: pointer to a GMAC_HANDLE structure that contains
 | 
				
			||||||
 | 
					 *                the information for GMAC module.
 | 
				
			||||||
 | 
					 * @param  extClk: 0: select clk_mac as the clock of mac
 | 
				
			||||||
 | 
					 *                 1: select external phy clock as the clock of mac
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_GMAC_SetExtclkSrc(struct GMAC_HANDLE *pGMAC, bool extClk)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t *cruCon, val;
 | 
				
			||||||
 | 
					    uint32_t clksel = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    cruCon = (uint32_t *)((pGMAC->pReg == GMAC1) ? &(CRU->CRU_CLKSEL_CON[33]) :
 | 
				
			||||||
 | 
					                                                   &(CRU->CRU_CLKSEL_CON[31]));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (extClk) {
 | 
				
			||||||
 | 
					        clksel = 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    val = HIWORD_UPDATE(clksel, 0x1, 2);
 | 
				
			||||||
 | 
					    WRITE_REG(*cruCon, val);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set RGMII speed.
 | 
				
			||||||
 | 
					 * @param  pGMAC: pointer to a GMAC_HANDLE structure that contains
 | 
				
			||||||
 | 
					 *                the information for GMAC module.
 | 
				
			||||||
 | 
					 * @param  speed: RGMII speed 10/100/1000
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_GMAC_SetRGMIISpeed(struct GMAC_HANDLE *pGMAC, int32_t speed)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    eCLOCK_Name clkID;
 | 
				
			||||||
 | 
					    uint32_t rate;
 | 
				
			||||||
 | 
					    int32_t ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    switch (speed) {
 | 
				
			||||||
 | 
					    case 10:
 | 
				
			||||||
 | 
					        rate = 2500000;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case 100:
 | 
				
			||||||
 | 
					        rate = 25000000;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case 1000:
 | 
				
			||||||
 | 
					        rate = 125000000;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    default:
 | 
				
			||||||
 | 
					        HAL_DBG_ERR("unknown speed value for GMAC speed=%ld", speed);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (pGMAC->phyStatus.interface == PHY_INTERFACE_MODE_RMII) {
 | 
				
			||||||
 | 
					        clkID = (pGMAC->pReg == GMAC1) ? SCLK_GMAC1_RMII_SPEED :
 | 
				
			||||||
 | 
					                                         SCLK_GMAC0_RMII_SPEED;
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        clkID = (pGMAC->pReg == GMAC1) ? SCLK_GMAC1_RGMII_SPEED :
 | 
				
			||||||
 | 
					                                         SCLK_GMAC0_RGMII_SPEED;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    ret = HAL_CRU_ClkSetFreq(clkID, rate);
 | 
				
			||||||
 | 
					    if (ret) {
 | 
				
			||||||
 | 
					        HAL_DBG_ERR("%s: set clk_mac_speed rate %ld failed %ld\n",
 | 
				
			||||||
 | 
					                    __func__, rate, ret);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set RGMII speed.
 | 
				
			||||||
 | 
					 * @param  pGMAC: pointer to a GMAC_HANDLE structure that contains
 | 
				
			||||||
 | 
					 *                the information for GMAC module.
 | 
				
			||||||
 | 
					 * @param  speed: RGMII speed 10/100
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_GMAC_SetRMIISpeed(struct GMAC_HANDLE *pGMAC, int32_t speed)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_GMAC_SetRGMIISpeed(pGMAC, speed);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,333 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_base.h"
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					#include "hal_bsp.h"
 | 
				
			||||||
 | 
					#include "hal_timer.h"
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup HAL_BASE
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup HAL_BASE_How_To_Use How To Use
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 HAL system support is including delay system, HAL tick system and global system clock,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 HAL system tick setting:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 - Attach HAL_IncTick() to system tick interrupt handler;
 | 
				
			||||||
 | 
					 - Notify the HAL system the system's tick frequency by calling HAL_SetTickFreq() unless
 | 
				
			||||||
 | 
					    it is the same as default value HAL_TICK_FREQ_1KHZ;
 | 
				
			||||||
 | 
					 - If you need a more accurate delay system, specify SYS_TIMER in hal_conf.h.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Init HAL system:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 - Initialize the HAL system by calling HAL_Init():
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Reset when SOC system is changed:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 - Update system with new core clock and new SysTick clock source by calling HAL_SystemCoreClockUpdate();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 APIs:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 - Get system time by calling HAL_GetTick().
 | 
				
			||||||
 | 
					 - Delay for a certain length of time, HAL_DelayMs(), HAL_DelayUs(), and HAL_CPUDelayUs().
 | 
				
			||||||
 | 
					 - Blocking for a certain period of time to continuously query HW status, use HAL_GetTick()
 | 
				
			||||||
 | 
					 to do timeout, this will be more accurate.
 | 
				
			||||||
 | 
					 - Get current cpu usage by calling HAL_GetCPUUsage().
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup HAL_BASE_Private_Definition Private Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/********************* Private MACRO Definition ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_TICK_FREQ_DEFAULT HAL_TICK_FREQ_1KHZ
 | 
				
			||||||
 | 
					#define  SYSTEM_CLOCK  816000000U
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*----------------------------------------------------------------------------
 | 
				
			||||||
 | 
					  System Core Clock Variable
 | 
				
			||||||
 | 
					 *----------------------------------------------------------------------------*/
 | 
				
			||||||
 | 
					uint32_t SystemCoreClock = SYSTEM_CLOCK;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*----------------------------------------------------------------------------
 | 
				
			||||||
 | 
					  System Core Clock update function
 | 
				
			||||||
 | 
					 *----------------------------------------------------------------------------*/
 | 
				
			||||||
 | 
					void SystemCoreClockUpdate (void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    SystemCoreClock = SYSTEM_CLOCK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					/********************* Private Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Variable Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static __IO uint32_t uwTick;
 | 
				
			||||||
 | 
					static eHAL_tickFreq uwTickFreq = HAL_TICK_FREQ_DEFAULT;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Function Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void CPUCycleLoop(uint32_t cycles)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    __asm volatile (
 | 
				
			||||||
 | 
					        "mov  r0, %0\n\t"
 | 
				
			||||||
 | 
					        "adds r0, r0, #2\n\t"   //    1    2    Round to the nearest multiple of 4.
 | 
				
			||||||
 | 
					        "lsrs r0, r0, #2\n\t"   //    1    2    Divide by 4 and set flags.
 | 
				
			||||||
 | 
					        "beq  2f\n\t"           //    2    2    Skip if 0.
 | 
				
			||||||
 | 
					        ".align 4\n\t"
 | 
				
			||||||
 | 
					        "1:\n\t"
 | 
				
			||||||
 | 
					        "adds r0, r0, #1\n\t"   //    1    2    Increment the counter.
 | 
				
			||||||
 | 
					        "subs r0, r0, #2\n\t"   //    1    2    Decrement the counter by 2.
 | 
				
			||||||
 | 
					        "bne  1b\n\t"           //   (1)2  2    2 CPU cycles (if branch is taken).
 | 
				
			||||||
 | 
					        "nop\n\t"               //    1    2    Loop alignment padding.
 | 
				
			||||||
 | 
					        "2:"
 | 
				
			||||||
 | 
					        : : "r" (cycles)
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static inline HAL_Status TimerDelayUs(uint32_t us)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint64_t count, from, now, pass;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    from = HAL_TIMER_GetCount(SYS_TIMER);
 | 
				
			||||||
 | 
					    count = PLL_INPUT_OSC_RATE / 1000000 * us;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    do {
 | 
				
			||||||
 | 
					        now = HAL_TIMER_GetCount(SYS_TIMER);
 | 
				
			||||||
 | 
					        pass = now > from ? now - from : from - now;
 | 
				
			||||||
 | 
					    } while (pass < count);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/********************* Public Function Definition ***************************/
 | 
				
			||||||
 | 
					/** @defgroup HAL_BASE_Exported_Functions_Group4 Init and DeInit Functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 This section provides functions allowing to init and deinit the module:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Init HAL driver basic code.
 | 
				
			||||||
 | 
					 * @return HAL_OK.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  HAL system update with new core clock and systick clock source.
 | 
				
			||||||
 | 
					 * @param  hz: new core clock.
 | 
				
			||||||
 | 
					 * @param  clkSource: new systick clock source.
 | 
				
			||||||
 | 
					 * @return HAL_OK.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_SystemCoreClockUpdate(uint32_t hz, eHAL_systickClkSource clkSource)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t rate = hz;
 | 
				
			||||||
 | 
					    HAL_Status ret = HAL_OK;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(__CORTEX_M) && defined(HAL_SYSTICK_MODULE_ENABLED)
 | 
				
			||||||
 | 
					    ret = HAL_SYSTICK_CLKSourceConfig(clkSource);
 | 
				
			||||||
 | 
					    if (ret == HAL_OK && clkSource == HAL_SYSTICK_CLKSRC_EXT) {
 | 
				
			||||||
 | 
					        rate = PLL_INPUT_OSC_RATE;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    HAL_SYSTICK_Config(rate / (1000 / HAL_GetTickFreq()));
 | 
				
			||||||
 | 
					    ret = HAL_OK;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (ret == HAL_OK) {
 | 
				
			||||||
 | 
					        SystemCoreClock = rate;   /* Update global SystemCoreClock */
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return ret;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup HAL_BASE_Exported_Functions_Group5 Other Functions
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Count plus tickFreq when interrupt occurs.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_IncTick(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uwTick += uwTickFreq;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Provides tick value in millisecond.
 | 
				
			||||||
 | 
					 * @return uint32_t: tick value in millisecond.
 | 
				
			||||||
 | 
					 * @attention this API allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					uint32_t HAL_GetTick(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    uint64_t tick = HAL_TIMER_GetCount(SYS_TIMER);
 | 
				
			||||||
 | 
					    uint32_t base = PLL_INPUT_OSC_RATE / 1000;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (tick >> 62) {
 | 
				
			||||||
 | 
					        tick = ~tick;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return (uint32_t)HAL_DivU64(tick, base);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Provides system timer count.
 | 
				
			||||||
 | 
					 * @return uint64_t: timer count.
 | 
				
			||||||
 | 
					 * @attention this API allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					uint64_t HAL_GetSysTimerCount(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    uint64_t count = HAL_TIMER_GetCount(SYS_TIMER);
 | 
				
			||||||
 | 
					    if (count >> 62) {
 | 
				
			||||||
 | 
					        count = ~count;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return count;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief Set new tick frequency.
 | 
				
			||||||
 | 
					  * @return HAL_Status.
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					HAL_Status HAL_SetTickFreq(eHAL_tickFreq freq)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    // HAL_ASSERT(IS_TICKFREQ(freq));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    uwTickFreq = freq;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief Return tick frequency.
 | 
				
			||||||
 | 
					  * @return uint32_t: tick period in Hz.
 | 
				
			||||||
 | 
					  * @attention this API allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					eHAL_tickFreq HAL_GetTickFreq(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return uwTickFreq;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  SysTick mdelay.
 | 
				
			||||||
 | 
					 * @param  ms: mdelay count.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK.
 | 
				
			||||||
 | 
					 * @attention this API allow direct use in the HAL layer. Blocking for a
 | 
				
			||||||
 | 
					 *  certain period of time to continuously query HW status, use HAL_GetTick
 | 
				
			||||||
 | 
					 *  to do timeout, that will be more accurate.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					__attribute__((weak)) HAL_Status HAL_DelayMs(uint32_t ms)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    for (uint32_t i = 0; i < ms; i++) {
 | 
				
			||||||
 | 
					        HAL_DelayUs(1000);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  SysTick udelay.
 | 
				
			||||||
 | 
					 * @param  us: udelay count.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK.
 | 
				
			||||||
 | 
					 * @attention this API allow direct use in the HAL layer. The longer the delay,
 | 
				
			||||||
 | 
					 *  the more accurate. Actual delay is greater than the parameter.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_DelayUs(uint32_t us)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if defined(SYS_TIMER) && defined(HAL_TIMER_MODULE_ENABLED)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return TimerDelayUs(us);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_CPUDelayUs(us);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  CPU loop udelay.
 | 
				
			||||||
 | 
					 * @param  us: udelay count.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK.
 | 
				
			||||||
 | 
					 * @attention this API allow direct use in the HAL layer. The longer the delay,
 | 
				
			||||||
 | 
					 *  the more accurate. Actual delay is greater than the parameter.
 | 
				
			||||||
 | 
					 *  During delay, CPU rate change result in delay imprecise, so call it in
 | 
				
			||||||
 | 
					 *  following case:
 | 
				
			||||||
 | 
					 *    1.IRQ disable
 | 
				
			||||||
 | 
					 *    2.CRU code
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CPUDelayUs(uint32_t us)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    volatile uint32_t cycles;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if (__CORTEX_M == 0)
 | 
				
			||||||
 | 
					    cycles = (uint32_t)HAL_DivU64((uint64_t)SystemCoreClock, 1000000) * us; /* Add few cycles penalty */
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    cycles = SystemCoreClock / 1000000 * us; /* Add few cycles penalty */
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    CPUCycleLoop(cycles);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					uint64_t HAL_DivU64Rem(uint64_t numerator, uint32_t denominator, uint32_t *pRemainder)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint64_t remainder = numerator;
 | 
				
			||||||
 | 
					    uint64_t b = denominator;
 | 
				
			||||||
 | 
					    uint64_t result;
 | 
				
			||||||
 | 
					    uint64_t d = 1;
 | 
				
			||||||
 | 
					    uint32_t high = numerator >> 32;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    result = 0;
 | 
				
			||||||
 | 
					    if (high >= denominator) {
 | 
				
			||||||
 | 
					        high /= denominator;
 | 
				
			||||||
 | 
					        result = (uint64_t)high << 32;
 | 
				
			||||||
 | 
					        remainder -= (uint64_t)(high * denominator) << 32;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    while ((int64_t)b > 0 && b < remainder) {
 | 
				
			||||||
 | 
					        b = b + b;
 | 
				
			||||||
 | 
					        d = d + d;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    do {
 | 
				
			||||||
 | 
					        if (remainder >= b) {
 | 
				
			||||||
 | 
					            remainder -= b;
 | 
				
			||||||
 | 
					            result += d;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        b >>= 1;
 | 
				
			||||||
 | 
					        d >>= 1;
 | 
				
			||||||
 | 
					    } while (d);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (pRemainder) {
 | 
				
			||||||
 | 
					        *pRemainder = remainder;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return result;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,33 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_bsp.h"
 | 
				
			||||||
 | 
					#include "rk3568.h"
 | 
				
			||||||
 | 
					#include "soc.h"
 | 
				
			||||||
 | 
					#include "hal_gmac.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const struct HAL_GMAC_DEV g_gmac0Dev =
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    .pReg = GMAC0,
 | 
				
			||||||
 | 
					    .clkID = CLK_MAC0_2TOP,
 | 
				
			||||||
 | 
					    .clkGateID = CLK_MAC0_2TOP_GATE,
 | 
				
			||||||
 | 
					    .pclkID = PCLK_PHP,
 | 
				
			||||||
 | 
					    .pclkGateID = PCLK_GMAC0_GATE,
 | 
				
			||||||
 | 
					    .irqNum = GMAC0_IRQn,
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const struct HAL_GMAC_DEV g_gmac1Dev =
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    .pReg = GMAC1,
 | 
				
			||||||
 | 
					    .clkID = CLK_MAC1_2TOP,
 | 
				
			||||||
 | 
					    .clkGateID = CLK_MAC1_2TOP_GATE,
 | 
				
			||||||
 | 
					    .pclkID = PCLK_USB,
 | 
				
			||||||
 | 
					    .pclkGateID = PCLK_GMAC1_GATE,
 | 
				
			||||||
 | 
					    .irqNum = GMAC1_IRQn,
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void BSP_Init(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| 
						 | 
					@ -0,0 +1,228 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup DEBUG
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup DEBUG_How_To_Use How To Use
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 The DEBUG driver can be used as follows:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Implement DBG hook:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 - printf func: define new HAL_SYSLOG in hal_conf.h or use HAL_DBG_Printf() in default;
 | 
				
			||||||
 | 
					 - assert func: redefine AssertFailed().
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Define debug level in hal_conf.h:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 - HAL_DBG_ON: print master switch;
 | 
				
			||||||
 | 
					 - HAL_DBG_INFO_ON: information printing switch;
 | 
				
			||||||
 | 
					 - HAL_DBG_WRN_ON: information printing switch;
 | 
				
			||||||
 | 
					 - HAL_DBG_ERR_ON: information printing switch;
 | 
				
			||||||
 | 
					 - HAL_ASSERT_ON: Support assert.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 APIS:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 - printf information by calling HAL_DBG();
 | 
				
			||||||
 | 
					 - printf warning by calling HAL_DBG_WRN();
 | 
				
			||||||
 | 
					 - printf error by calling HAL_DBG_ERR();
 | 
				
			||||||
 | 
					 - do assert by calling HAL_ASSERT().
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_base.h"
 | 
				
			||||||
 | 
					#include "hal_debug.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup DEBUG_Private_Definition Private Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/********************* Private MACRO Definition ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Variable Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Function Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/********************* Public Function Definition ****************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup DEBUG_Exported_Functions_Group5 Other Functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 This section provides functions allowing to init and deinit module as follows:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  Reports the name of the source file and the source line number
 | 
				
			||||||
 | 
					  *         where the HAL_ASSERT error has occurred.
 | 
				
			||||||
 | 
					  * @param  file: pointer to the source file name
 | 
				
			||||||
 | 
					  * @param  line: HAL_ASSERT error line source number
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					 __attribute__((weak)) void HAL_AssertFailed(const char *file, uint32_t line)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_DBG_ERR("assert failed at %s %lu\n", file, line);
 | 
				
			||||||
 | 
					    while (1) {
 | 
				
			||||||
 | 
					        ;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  format hex print.
 | 
				
			||||||
 | 
					 * @param  s: head tag for every new line.
 | 
				
			||||||
 | 
					 * @param  buf: buffer for printing.
 | 
				
			||||||
 | 
					 * @param  width: every single printed object width.
 | 
				
			||||||
 | 
					 * @param  len: the number of printed objects.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK.
 | 
				
			||||||
 | 
					 * sum = width * len (BYTE).
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_DBG_HEX(char *s, void *buf, uint32_t width, uint32_t len)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#ifdef HAL_DBG_ON
 | 
				
			||||||
 | 
					    uint32_t i, j;
 | 
				
			||||||
 | 
					    unsigned char *p8 = (unsigned char *)buf;
 | 
				
			||||||
 | 
					    unsigned short *p16 = (unsigned short *)buf;
 | 
				
			||||||
 | 
					    uint32_t *p32 = (uint32_t *)buf;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    j = 0;
 | 
				
			||||||
 | 
					    for (i = 0; i < len; i++) {
 | 
				
			||||||
 | 
					        if (j == 0) {
 | 
				
			||||||
 | 
					            HAL_SYSLOG("[HAL_DBG_HEX] %s %p + 0x%lx:", s, buf, i * width);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (width == 4) {
 | 
				
			||||||
 | 
					            HAL_SYSLOG("0x%08lx,", p32[i]);
 | 
				
			||||||
 | 
					        } else if (width == 2) {
 | 
				
			||||||
 | 
					            HAL_SYSLOG("0x%04x,", p16[i]);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            HAL_SYSLOG("0x%02x,", p8[i]);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (++j >= 16) {
 | 
				
			||||||
 | 
					            j = 0;
 | 
				
			||||||
 | 
					            HAL_SYSLOG("\n");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    HAL_SYSLOG("\n");
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAL_DBG_USING_HAL_PRINTF
 | 
				
			||||||
 | 
					static void reverse(char *start, char *end)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    while (start < end) {
 | 
				
			||||||
 | 
					        char temp = *start;
 | 
				
			||||||
 | 
					        *start = *end;
 | 
				
			||||||
 | 
					        *end = temp;
 | 
				
			||||||
 | 
					        start++;
 | 
				
			||||||
 | 
					        end--;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __GNUC__
 | 
				
			||||||
 | 
					extern int _write(int fd, char *ptr, int len);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  format and print data
 | 
				
			||||||
 | 
					 * @param  format: format printf param. only support: \%d, \%s, \%ld, \%lld
 | 
				
			||||||
 | 
					 * @return int32_t.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					 __attribute__((weak)) int32_t HAL_DBG_Printf(const char *format, ...)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    static char g_printf_buf[HAL_PRINTF_BUF_SIZE];
 | 
				
			||||||
 | 
					    char *str = g_printf_buf;
 | 
				
			||||||
 | 
					    int32_t len = 0;
 | 
				
			||||||
 | 
					    va_list args;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    va_start(args, format);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    while (*format != '\0') {
 | 
				
			||||||
 | 
					        if (*format == '%') {
 | 
				
			||||||
 | 
					            format++;
 | 
				
			||||||
 | 
					            if (*format == 'd') {
 | 
				
			||||||
 | 
					                int i = va_arg(args, int);
 | 
				
			||||||
 | 
					                char *start = str;
 | 
				
			||||||
 | 
					                do {
 | 
				
			||||||
 | 
					                    *str++ = '0' + (i % 10);
 | 
				
			||||||
 | 
					                    i /= 10;
 | 
				
			||||||
 | 
					                } while (i > 0);
 | 
				
			||||||
 | 
					                reverse(start, str - 1);
 | 
				
			||||||
 | 
					            } else if (*format == 's') {
 | 
				
			||||||
 | 
					                char *s = va_arg(args, char *);
 | 
				
			||||||
 | 
					                while (*s) {
 | 
				
			||||||
 | 
					                    *str++ = *s++;
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					            } else if (*format == 'l') {
 | 
				
			||||||
 | 
					                format++;
 | 
				
			||||||
 | 
					                if (*format == 'd') {
 | 
				
			||||||
 | 
					                    long i = va_arg(args, long);
 | 
				
			||||||
 | 
					                    char *start = str;
 | 
				
			||||||
 | 
					                    do {
 | 
				
			||||||
 | 
					                        *str++ = '0' + (i % 10);
 | 
				
			||||||
 | 
					                        i /= 10;
 | 
				
			||||||
 | 
					                    } while (i > 0);
 | 
				
			||||||
 | 
					                    reverse(start, str - 1);
 | 
				
			||||||
 | 
					                } else if (*format == 'l') {
 | 
				
			||||||
 | 
					                    format++;
 | 
				
			||||||
 | 
					                    if (*format == 'd') {
 | 
				
			||||||
 | 
					                        long long int i = va_arg(args, long long int);
 | 
				
			||||||
 | 
					                        char *start = str;
 | 
				
			||||||
 | 
					                        do {
 | 
				
			||||||
 | 
					                            *str++ = '0' + (i % 10);
 | 
				
			||||||
 | 
					                            i /= 10;
 | 
				
			||||||
 | 
					                        } while (i > 0);
 | 
				
			||||||
 | 
					                        reverse(start, str - 1);
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            *str++ = *format;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        format++;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    *str = '\0';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    va_end(args);
 | 
				
			||||||
 | 
					    len = str - g_printf_buf;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __GNUC__
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return _write(2, g_printf_buf, len);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    for (int i = 0; i < len; i++) {
 | 
				
			||||||
 | 
					        fputc(g_printf_buf[i], stdout);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return len;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  format and print data
 | 
				
			||||||
 | 
					 * @param  format: format printf param.
 | 
				
			||||||
 | 
					 * @return int32_t.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					 __attribute__((weak)) int32_t HAL_DBG_Printf(const char *format, ...)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif /* HAL_DBG_USING_HAL_PRINTF */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,577 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_base.h"
 | 
				
			||||||
 | 
					#include "hal_pinctrl.h"
 | 
				
			||||||
 | 
					#include "hal_gpio.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup GPIO
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup GPIO_How_To_Use How To Use
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 The GPIO driver can be used as follows:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 APIs for GPIO io read write:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					   1. HAL_GPIO_GetPinLevel() to get EXT port level.
 | 
				
			||||||
 | 
					   2. HAL_GPIO_SetPinLevel() to set io level.
 | 
				
			||||||
 | 
					   3. HAL_GPIO_SetPinDirection() to set io direction.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 APIs for GPIO IRQ:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					   1. HAL_GPIO_EnableIRQ() to enable a GPIO IRQ.
 | 
				
			||||||
 | 
					   2. HAL_GPIO_DisableIRQ() to disable a GPIO IRQ.
 | 
				
			||||||
 | 
					   3. HAL_GPIO_IRQHandler() to handle GPIO IRQ isr.
 | 
				
			||||||
 | 
					   4. HAL_GPIO_IRQDispatch() to dispatch GPIO IRQ, should be implemented by User.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Please open the macro definition HAL_GPIO_VIRTUAL_MODEL_FEATURE_ENABLED to support
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 APIs for GPIO virtual model:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					   1. HAL_GPIO_EnableVirtualModel() to enable a GPIO virtual model.
 | 
				
			||||||
 | 
					   2. HAL_GPIO_DisableVirtualModel() to disable a GPIO virtual model.
 | 
				
			||||||
 | 
					   3. HAL_GPIO_SetVirtualModel() to configure GPIO pins virtual model.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup GPIO_Private_Definition Private Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/********************* Private MACRO Definition ******************************/
 | 
				
			||||||
 | 
					#define UNUSED(X) (void)(X)      /* To avoid gcc/g++ warnings */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Function Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set the GPIO IRQ end of interrupt(EOI).
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pin: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static void GPIO_SetEOI(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    if (IS_GPIO_HIGH_PIN(pin)) {
 | 
				
			||||||
 | 
					        pin &= 0xFFFF0000;
 | 
				
			||||||
 | 
					        pGPIO->PORT_EOI_H = pin | (pin >> 16);
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        pin &= 0x0000FFFF;
 | 
				
			||||||
 | 
					        pGPIO->PORT_EOI_L = pin | (pin << 16);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        pGPIO->PORTA_EOI = pin;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get GPIO all pins irq type.
 | 
				
			||||||
 | 
					 * @param  pGPIO: the GPIO struct.
 | 
				
			||||||
 | 
					 * @return uint32_t: type value.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static uint32_t GPIO_GetIntType(struct GPIO_REG *pGPIO)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    type = (pGPIO->INT_TYPE_L & 0xffff);
 | 
				
			||||||
 | 
					    type |= ((pGPIO->INT_TYPE_H & 0xffff) << 16);
 | 
				
			||||||
 | 
					    type |= (pGPIO->INT_BOTHEDGE_L & 0xffff);
 | 
				
			||||||
 | 
					    type |= ((pGPIO->INT_BOTHEDGE_H & 0xffff) << 16);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    type = pGPIO->INTTYPE_LEVEL;
 | 
				
			||||||
 | 
					    #ifdef GPIO_INT_BOTHEDGE_OFFSET
 | 
				
			||||||
 | 
					    type |= pGPIO->INT_BOTHEDGE;
 | 
				
			||||||
 | 
					    #endif
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return type;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get GPIO all pins irq status.
 | 
				
			||||||
 | 
					 * @param  pGPIO: the GPIO struct.
 | 
				
			||||||
 | 
					 * @return uint32_t: status value.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static uint32_t GPIO_GetIntStatus(struct GPIO_REG *pGPIO)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return pGPIO->INT_STATUS;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/********************* Public Function Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup GPIO_Exported_Functions_Group1 State and Errors Functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 This section provides functions allowing to get the status of the module:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  GPIO Configure IRQ trigger type.
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pin: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @param  mode: The value defined in @ref eGPIO_intType.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetIntType(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin, eGPIO_intType mode)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t both = 0, type = 0, plar = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    UNUSED(both);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    switch (mode) {
 | 
				
			||||||
 | 
					    case GPIO_INT_TYPE_EDGE_RISING:
 | 
				
			||||||
 | 
					        type = 1;
 | 
				
			||||||
 | 
					        plar = 1;
 | 
				
			||||||
 | 
					        both = 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case GPIO_INT_TYPE_EDGE_FALLING:
 | 
				
			||||||
 | 
					        type = 1;
 | 
				
			||||||
 | 
					        plar = 0;
 | 
				
			||||||
 | 
					        both = 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case GPIO_INT_TYPE_LEVEL_HIGH:
 | 
				
			||||||
 | 
					        type = 0;
 | 
				
			||||||
 | 
					        plar = 1;
 | 
				
			||||||
 | 
					        both = 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case GPIO_INT_TYPE_LEVEL_LOW:
 | 
				
			||||||
 | 
					        type = 0;
 | 
				
			||||||
 | 
					        plar = 0;
 | 
				
			||||||
 | 
					        both = 0;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    case GPIO_INT_TYPE_EDGE_BOTH:
 | 
				
			||||||
 | 
					        type = 0;
 | 
				
			||||||
 | 
					        plar = 0;
 | 
				
			||||||
 | 
					        both = 1;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    default:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return HAL_INVAL;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    if (IS_GPIO_HIGH_PIN(pin)) {
 | 
				
			||||||
 | 
					        pin &= 0xFFFF0000;
 | 
				
			||||||
 | 
					        pGPIO->INT_TYPE_H = (type) ? (pin | (pin >> 16)) : (pin);
 | 
				
			||||||
 | 
					        pGPIO->INT_POLARITY_H = (plar) ? (pin | (pin >> 16)) : (pin);
 | 
				
			||||||
 | 
					        pGPIO->INT_BOTHEDGE_H = (both) ? (pin | (pin >> 16)) : (pin);
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        pin &= 0x0000FFFF;
 | 
				
			||||||
 | 
					        pGPIO->INT_TYPE_L = (type) ? (pin | (pin << 16)) : (pin << 16);
 | 
				
			||||||
 | 
					        pGPIO->INT_POLARITY_L = (plar) ? (pin | (pin << 16)) : (pin << 16);
 | 
				
			||||||
 | 
					        pGPIO->INT_BOTHEDGE_L = (both) ? (pin | (pin << 16)) : (pin << 16);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        pGPIO->INTTYPE_LEVEL = (type) ? (pin) : (pGPIO->INTTYPE_LEVEL & ~(pin));
 | 
				
			||||||
 | 
					        pGPIO->INT_POLARITY = (plar) ? (pin) : (pGPIO->INT_POLARITY & ~(pin));
 | 
				
			||||||
 | 
					        #ifdef GPIO_INT_BOTHEDGE_OFFSET
 | 
				
			||||||
 | 
					        pGPIO->INT_BOTHEDGE = (both) ? (pin) : (pGPIO->INT_BOTHEDGE & ~(pin));
 | 
				
			||||||
 | 
					        #endif
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set GPIO direction.
 | 
				
			||||||
 | 
					 * @param  pGPIO: the GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pin: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @param  direction: direction value defined in @ref eGPIO_pinDirection.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK if success.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetPinDirection(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin, eGPIO_pinDirection direction)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    if (IS_GPIO_HIGH_PIN(pin)) {
 | 
				
			||||||
 | 
					        pin &= 0xFFFF0000;
 | 
				
			||||||
 | 
					        pGPIO->SWPORT_DDR_H = (direction == GPIO_OUT) ? (pin | (pin >> 16)) : (pin);
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        pin &= 0x0000FFFF;
 | 
				
			||||||
 | 
					        pGPIO->SWPORT_DDR_L = (direction == GPIO_OUT) ? (pin | (pin << 16)) : (pin << 16);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    if (direction == GPIO_OUT) {
 | 
				
			||||||
 | 
					        pGPIO->SWPORTA_DDR |= pin;
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        pGPIO->SWPORTA_DDR &= ~pin;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set GPIO direction.
 | 
				
			||||||
 | 
					 * @param  pGPIO: the GPIO struct.
 | 
				
			||||||
 | 
					 * @param  mPins: The pins defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @param  direction: value defined in @ref eGPIO_pinDirection.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK if success.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetPinsDirection(struct GPIO_REG *pGPIO, uint32_t mPins, eGPIO_pinDirection direction)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint8_t pin;
 | 
				
			||||||
 | 
					    HAL_Status rc;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_GPIO_INSTANCE(pGPIO));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for (pin = 0; pin < 32; pin++) {
 | 
				
			||||||
 | 
					        if (mPins & (1 << pin)) {
 | 
				
			||||||
 | 
					            rc = HAL_GPIO_SetPinDirection(pGPIO, (1 << pin), direction);
 | 
				
			||||||
 | 
					            if (rc) {
 | 
				
			||||||
 | 
					                return rc;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get GPIO Pin data direction value.
 | 
				
			||||||
 | 
					 * @param  pGPIO: the GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pin: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @retval eGPIO_pinDirection: data direction value.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					eGPIO_pinDirection HAL_GPIO_GetPinDirection(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    eGPIO_pinDirection direction;
 | 
				
			||||||
 | 
					    uint32_t value;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    value = IS_GPIO_HIGH_PIN(pin) ? (pGPIO->SWPORT_DDR_H & (pin >> 16)) : (pGPIO->SWPORT_DDR_L & pin);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    value = pGPIO->SWPORTA_DDR & pin;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (value != (uint32_t)GPIO_IN) {
 | 
				
			||||||
 | 
					        direction = GPIO_OUT;
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        direction = GPIO_IN;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return direction;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set GPIO pin level.
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pin: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @param  level: The level defined in @ref eGPIO_pinLevel.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetPinLevel(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin, eGPIO_pinLevel level)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    if (IS_GPIO_HIGH_PIN(pin)) {
 | 
				
			||||||
 | 
					        pin &= 0xFFFF0000;
 | 
				
			||||||
 | 
					        pGPIO->SWPORT_DR_H = (level == GPIO_HIGH) ? (pin | (pin >> 16)) : (pin);
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        pin &= 0x0000FFFF;
 | 
				
			||||||
 | 
					        pGPIO->SWPORT_DR_L = (level == GPIO_HIGH) ? (pin | (pin << 16)) : (pin << 16);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    if (level == GPIO_HIGH) {
 | 
				
			||||||
 | 
					        pGPIO->SWPORTA_DR |= pin;
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        pGPIO->SWPORTA_DR &= ~pin;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set GPIO pin level.
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @param  mPins: The pins defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @param  level: The level defined in @ref eGPIO_pinLevel.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetPinsLevel(struct GPIO_REG *pGPIO, uint32_t mPins, eGPIO_pinLevel level)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint8_t pin;
 | 
				
			||||||
 | 
					    HAL_Status rc;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_GPIO_INSTANCE(pGPIO));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for (pin = 0; pin < 32; pin++) {
 | 
				
			||||||
 | 
					        if (mPins & (1 << pin)) {
 | 
				
			||||||
 | 
					            rc = HAL_GPIO_SetPinLevel(pGPIO, (1 << pin), level);
 | 
				
			||||||
 | 
					            if (rc) {
 | 
				
			||||||
 | 
					                return rc;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup GPIO_Exported_Functions_Group2 IO Functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 This section provides functions allowing to IO controlling:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get GPIO Pin data value.
 | 
				
			||||||
 | 
					 * @param  pGPIO: the GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pin: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @retval eGPIO_pinLevel: data value.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					eGPIO_pinLevel HAL_GPIO_GetPinData(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    eGPIO_pinLevel level;
 | 
				
			||||||
 | 
					    uint32_t value;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    value = IS_GPIO_HIGH_PIN(pin) ? (pGPIO->SWPORT_DR_H & (pin >> 16)) : (pGPIO->SWPORT_DR_L & pin);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    value = pGPIO->SWPORTA_DR & pin;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (value != (uint32_t)GPIO_LOW) {
 | 
				
			||||||
 | 
					        level = GPIO_HIGH;
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        level = GPIO_LOW;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return level;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get GPIO Pin ext bank level.
 | 
				
			||||||
 | 
					 * @param  pGPIO: the GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pin: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @retval GPIO_PinState: ext bank value.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					eGPIO_pinLevel HAL_GPIO_GetPinLevel(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t value;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    value = (pGPIO->EXT_PORT & pin);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    value = (pGPIO->EXT_PORTA & pin);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return (value == (uint32_t)GPIO_LOW) ? GPIO_LOW : GPIO_HIGH;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get GPIO Pin ext bank level.
 | 
				
			||||||
 | 
					 * @param  pGPIO: the GPIO struct.
 | 
				
			||||||
 | 
					 * @retval uint32_t: ext bank value.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					uint32_t HAL_GPIO_GetBankLevel(struct GPIO_REG *pGPIO)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t value;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    value = (pGPIO->EXT_PORT);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    value = (pGPIO->EXT_PORTA);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return value;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup GPIO_Exported_Functions_Group3 Other Functions
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set GPIO irq enable.
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pin: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_GPIO_EnableIRQ(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    if (IS_GPIO_HIGH_PIN(pin)) {
 | 
				
			||||||
 | 
					        pin &= 0xFFFF0000;
 | 
				
			||||||
 | 
					#ifndef HAL_GPIO_IRQ_GROUP_MODULE_ENABLED
 | 
				
			||||||
 | 
					        pGPIO->INT_MASK_H = pin;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					        pGPIO->INT_EN_H = pin | (pin >> 16);
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        pin &= 0x0000FFFF;
 | 
				
			||||||
 | 
					#ifndef HAL_GPIO_IRQ_GROUP_MODULE_ENABLED
 | 
				
			||||||
 | 
					        pGPIO->INT_MASK_L = pin << 16;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					        pGPIO->INT_EN_L = pin | (pin << 16);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        pGPIO->INTEN |= pin;
 | 
				
			||||||
 | 
					        pGPIO->INTMASK &= ~pin;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set GPIO irq disable.
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pin: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_GPIO_DisableIRQ(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    if (IS_GPIO_HIGH_PIN(pin)) {
 | 
				
			||||||
 | 
					        pin &= 0xFFFF0000;
 | 
				
			||||||
 | 
					        pGPIO->INT_EN_H = pin;
 | 
				
			||||||
 | 
					#ifndef HAL_GPIO_IRQ_GROUP_MODULE_ENABLED
 | 
				
			||||||
 | 
					        pGPIO->INT_MASK_H = pin | (pin >> 16);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        pin &= 0x0000FFFF;
 | 
				
			||||||
 | 
					        pGPIO->INT_EN_L = pin << 16;
 | 
				
			||||||
 | 
					#ifndef HAL_GPIO_IRQ_GROUP_MODULE_ENABLED
 | 
				
			||||||
 | 
					        pGPIO->INT_MASK_L = pin | (pin << 16);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        pGPIO->INTEN &= ~pin;
 | 
				
			||||||
 | 
					        pGPIO->INTMASK |= pin;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  GPIO IRQ callbacks.
 | 
				
			||||||
 | 
					 * @param  bank: The bank id.
 | 
				
			||||||
 | 
					 * @param  pin: The true pin index, 0~31.
 | 
				
			||||||
 | 
					 * NOTE: This function Should not be modified, when the callback is needed,
 | 
				
			||||||
 | 
					 *       the HAL_GPIO_IRQDispatch could be implemented in the user file.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					__attribute__((weak)) void HAL_GPIO_IRQDispatch(eGPIO_bankId bank, uint32_t pin)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    UNUSED(bank);
 | 
				
			||||||
 | 
					    UNUSED(pin);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  GPIO IRQ hanlder.
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @param  bank: The bank id.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_GPIO_IRQHandler(struct GPIO_REG *pGPIO, eGPIO_bankId bank)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t stat, type, clear;
 | 
				
			||||||
 | 
					    uint32_t i;
 | 
				
			||||||
 | 
					    uint32_t pin;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    stat = GPIO_GetIntStatus(pGPIO);
 | 
				
			||||||
 | 
					    type = GPIO_GetIntType(pGPIO);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* Then process each pending GPIO interrupt */
 | 
				
			||||||
 | 
					    for (i = 0x0U; i < PIN_NUMBER_PER_BANK && stat != 0; i++) {
 | 
				
			||||||
 | 
					        clear = 0x1U << i;
 | 
				
			||||||
 | 
					        pin = HAL_BIT(i);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if ((stat & clear) != 0x0U) {
 | 
				
			||||||
 | 
					            /* If gpio is Edge-sensitive triggered, clear eoi */
 | 
				
			||||||
 | 
					            if (type & clear) {
 | 
				
			||||||
 | 
					                GPIO_SetEOI(pGPIO, pin);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            /* Remove the pending interrupt bit from the clear */
 | 
				
			||||||
 | 
					            stat &= ~clear;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            /* And disptach the GPIO interrupt to the handler */
 | 
				
			||||||
 | 
					            HAL_GPIO_IRQDispatch(bank, i);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAL_GPIO_VIRTUAL_MODEL_FEATURE_ENABLED
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  GPIO virtual model enable.
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_EnableVirtualModel(struct GPIO_REG *pGPIO)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    pGPIO->GPIO_VIRTUAL_EN = 0x10001;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_ERROR;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  GPIO virtual model disable.
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_DisableVirtualModel(struct GPIO_REG *pGPIO)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    pGPIO->GPIO_VIRTUAL_EN = 0x10000;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_ERROR;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  GPIO Configure pins for virtual model.
 | 
				
			||||||
 | 
					 * @param  pGPIO: The pointer of GPIO struct.
 | 
				
			||||||
 | 
					 * @param  pins: The pin bit defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @param  vmode: The value defined in @ref eGPIO_VirtualModel.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetVirtualModel(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin, eGPIO_VirtualModel vmodel)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#if (GPIO_VER_ID == 0x01000C2BU)
 | 
				
			||||||
 | 
					    uint32_t low_pins, high_pins;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    low_pins = pin & 0x0000ffff;
 | 
				
			||||||
 | 
					    high_pins = (pin & 0xffff0000) >> 16;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* Support OS_A and OS_B */
 | 
				
			||||||
 | 
					    if (vmodel == GPIO_VIRTUAL_MODEL_OS_B) {
 | 
				
			||||||
 | 
					        pGPIO->GPIO_REG_GROUP_L = low_pins << 16;
 | 
				
			||||||
 | 
					        pGPIO->GPIO_REG_GROUP_H = high_pins << 16;
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        pGPIO->GPIO_REG_GROUP_L = low_pins | (low_pins << 16);
 | 
				
			||||||
 | 
					        pGPIO->GPIO_REG_GROUP_H = high_pins | (high_pins << 16);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_ERROR;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif /* HAL_GPIO_VIRTUAL_MODEL_FEATURE_ENABLED */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,565 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_base.h"
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					#include "hal_pinctrl.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup PINCTRL
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup PINCTRL_How_To_Use How To Use
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 The pinctrl setting registers actually is bus grf registers, which include
 | 
				
			||||||
 | 
					 iomux, drive strength, pull mode, slew rate and schmitt trigger.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 The pinctrl driver provides APIs:
 | 
				
			||||||
 | 
					   - HAL_PINCTRL_SetIOMUX() to set pin iomux
 | 
				
			||||||
 | 
					   - HAL_PINCTRL_SetParam() to set pin iomux/drive/pull/slewrate/schmitt/ie
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Example:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     HAL_PINCTRL_SetIOMUX(GPIO_BANK0,
 | 
				
			||||||
 | 
					                          GPIO_PIN_A0 | // I2S_IN_SCLK
 | 
				
			||||||
 | 
					                          GPIO_PIN_A1 | // I2S_IN_LRCK
 | 
				
			||||||
 | 
					                          GPIO_PIN_A2 | // I2S_IN_SDI0
 | 
				
			||||||
 | 
					                          GPIO_PIN_A3,  // I2S_IN_SDI1
 | 
				
			||||||
 | 
					                          PIN_CONFIG_MUX_FUNC2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     HAL_PINCTRL_SetParam(GPIO_BANK0,
 | 
				
			||||||
 | 
					                          GPIO_PIN_A0 | // I2S_IN_SCLK
 | 
				
			||||||
 | 
					                          GPIO_PIN_A1 | // I2S_IN_LRCK
 | 
				
			||||||
 | 
					                          GPIO_PIN_A2 | // I2S_IN_SDI0
 | 
				
			||||||
 | 
					                          GPIO_PIN_A3,  // I2S_IN_SDI1
 | 
				
			||||||
 | 
					                          PIN_CONFIG_MUX_FUNC2 |
 | 
				
			||||||
 | 
					                          PIN_CONFIG_PUL_DOWN |
 | 
				
			||||||
 | 
					                          PIN_CONFIG_DRV_LEVEL2 |
 | 
				
			||||||
 | 
					                          PIN_CONFIG_SRT_FAST |
 | 
				
			||||||
 | 
					                          PIN_CONFIG_SMT_ENABLE);
 | 
				
			||||||
 | 
					 @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup PINCTRL_Private_Definition Private Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/********************* Private MACRO Definition ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define _TO_MASK(w)         ((1U << (w)) - 1U)
 | 
				
			||||||
 | 
					#define _TO_OFFSET(p, w)    ((p) * (w))
 | 
				
			||||||
 | 
					#define RK_GEN_VAL(p, v, w) ((_TO_MASK(w) << (_TO_OFFSET(p, w) + 16)) | (((v) & _TO_MASK(w)) << _TO_OFFSET(p, w)))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Use HAL_DBG("pinctrl: write val = 0x%lx to register %p\n", VAL, ®);
 | 
				
			||||||
 | 
					 * and HAL_DBG("pinctrl: readback register %p = 0x%lx\n", ®, REG);
 | 
				
			||||||
 | 
					 * for debug
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define _PINCTRL_WRITE(REG, DATA) \
 | 
				
			||||||
 | 
					{                                 \
 | 
				
			||||||
 | 
					    REG = DATA;                   \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(GRF_GPIO0A_IOMUX_OFFSET)
 | 
				
			||||||
 | 
					#define IOMUX_BIT_PER_PIN                 (2)
 | 
				
			||||||
 | 
					#define IOMUX_PIN_PER_REG                 (16 / IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define IOMUX_0(__B, __P)                 (GRF->GPIO##__B##__P##_IOMUX)
 | 
				
			||||||
 | 
					#define SET_IOMUX_0(_B, _P, p, v, w)      _PINCTRL_WRITE(IOMUX_0(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define RK_SET_IOMUX_0(B, P, p, v)        SET_IOMUX_0(B, P, p % IOMUX_PIN_PER_REG, v, IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define SET_IOMUX(_GPIO, _PORT, pin, val) RK_SET_IOMUX_0(_GPIO, _PORT, pin, val)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#elif defined(GRF_GPIO0A_IOMUX_H_OFFSET)
 | 
				
			||||||
 | 
					#define IOMUX_BIT_PER_PIN            (4)
 | 
				
			||||||
 | 
					#define IOMUX_PIN_PER_REG            (16 / IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define IOMUX_0(__B, __P)            (GRF->GPIO##__B##__P##_IOMUX_L)
 | 
				
			||||||
 | 
					#define IOMUX_1(__B, __P)            (GRF->GPIO##__B##__P##_IOMUX_H)
 | 
				
			||||||
 | 
					#define SET_IOMUX_0(_B, _P, p, v, w) _PINCTRL_WRITE(IOMUX_0(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_IOMUX_1(_B, _P, p, v, w) _PINCTRL_WRITE(IOMUX_1(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define RK_SET_IOMUX_0(B, P, p, v)   SET_IOMUX_0(B, P, p % IOMUX_PIN_PER_REG, v, IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_IOMUX_1(B, P, p, v)   SET_IOMUX_1(B, P, p % IOMUX_PIN_PER_REG, v, IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define SET_IOMUX(_GPIO, _PORT, pin, val)       \
 | 
				
			||||||
 | 
					{                                               \
 | 
				
			||||||
 | 
					    if ((pin % 8) < 4) {                        \
 | 
				
			||||||
 | 
					        RK_SET_IOMUX_0(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else {                                    \
 | 
				
			||||||
 | 
					        RK_SET_IOMUX_1(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    }                                           \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#elif defined(GRF_GPIO0A_IOMUX_0_OFFSET)
 | 
				
			||||||
 | 
					#define IOMUX_BIT_PER_PIN            (8)
 | 
				
			||||||
 | 
					#define IOMUX_PIN_PER_REG            (16 / IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define IOMUX_0(__B, __P)            (GRF->GPIO##__B##__P##_IOMUX_0)
 | 
				
			||||||
 | 
					#define IOMUX_1(__B, __P)            (GRF->GPIO##__B##__P##_IOMUX_1)
 | 
				
			||||||
 | 
					#define IOMUX_2(__B, __P)            (GRF->GPIO##__B##__P##_IOMUX_2)
 | 
				
			||||||
 | 
					#define IOMUX_3(__B, __P)            (GRF->GPIO##__B##__P##_IOMUX_3)
 | 
				
			||||||
 | 
					#define SET_IOMUX_0(_B, _P, p, v, w) _PINCTRL_WRITE(IOMUX_0(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_IOMUX_1(_B, _P, p, v, w) _PINCTRL_WRITE(IOMUX_1(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_IOMUX_2(_B, _P, p, v, w) _PINCTRL_WRITE(IOMUX_2(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_IOMUX_3(_B, _P, p, v, w) _PINCTRL_WRITE(IOMUX_3(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define RK_SET_IOMUX_0(B, P, p, v)   SET_IOMUX_0(B, P, p % IOMUX_PIN_PER_REG, v, IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_IOMUX_1(B, P, p, v)   SET_IOMUX_1(B, P, p % IOMUX_PIN_PER_REG, v, IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_IOMUX_2(B, P, p, v)   SET_IOMUX_2(B, P, p % IOMUX_PIN_PER_REG, v, IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_IOMUX_3(B, P, p, v)   SET_IOMUX_3(B, P, p % IOMUX_PIN_PER_REG, v, IOMUX_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define SET_IOMUX(_GPIO, _PORT, pin, val)       \
 | 
				
			||||||
 | 
					{                                               \
 | 
				
			||||||
 | 
					    if ((pin % 8) < 2) {                        \
 | 
				
			||||||
 | 
					        RK_SET_IOMUX_0(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else if ((pin % 8) < 4) {                 \
 | 
				
			||||||
 | 
					        RK_SET_IOMUX_1(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else if ((pin % 8) < 6) {                 \
 | 
				
			||||||
 | 
					        RK_SET_IOMUX_2(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else {                                    \
 | 
				
			||||||
 | 
					        RK_SET_IOMUX_3(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    }                                           \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(GRF_GPIO0A_DS_OFFSET)
 | 
				
			||||||
 | 
					#define DS_BIT_PER_PIN                 (2)
 | 
				
			||||||
 | 
					#define DS_PIN_PER_REG                 (16 / DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define DS_0(__B, __P)                 (GRF->GPIO##__B##__P##_DS)
 | 
				
			||||||
 | 
					#define SET_DS_0(_B, _P, p, v, w)      _PINCTRL_WRITE(DS_0(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define RK_SET_DS_0(B, P, p, v)        SET_DS_0(B, P, p % DS_PIN_PER_REG, v, DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define SET_DS(_GPIO, _PORT, pin, val) RK_SET_DS_0(_GPIO, _PORT, pin, val)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#elif defined(GRF_GPIO0A_DS_H_OFFSET)
 | 
				
			||||||
 | 
					#define DS_BIT_PER_PIN            (4)
 | 
				
			||||||
 | 
					#define DS_PIN_PER_REG            (16 / DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define DS_0(__B, __P)            (GRF->GPIO##__B##__P##_DS_L)
 | 
				
			||||||
 | 
					#define DS_1(__B, __P)            (GRF->GPIO##__B##__P##_DS_L)
 | 
				
			||||||
 | 
					#define SET_DS_0(_B, _P, p, v, w) _PINCTRL_WRITE(DS_0(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_DS_1(_B, _P, p, v, w) _PINCTRL_WRITE(DS_1(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define RK_SET_DS_0(B, P, p, v)   SET_DS_0(B, P, p % DS_PIN_PER_REG, v, DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_DS_1(B, P, p, v)   SET_DS_1(B, P, p % DS_PIN_PER_REG, v, DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define SET_DS(_GPIO, _PORT, pin, val)       \
 | 
				
			||||||
 | 
					{                                            \
 | 
				
			||||||
 | 
					    if ((pin % 8) < 4) {                     \
 | 
				
			||||||
 | 
					        RK_SET_DS_0(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else {                                 \
 | 
				
			||||||
 | 
					        RK_SET_DS_1(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    }                                        \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#elif defined(GRF_GPIO0A_DS_0_OFFSET)
 | 
				
			||||||
 | 
					#define DS_BIT_PER_PIN            (8)
 | 
				
			||||||
 | 
					#define DS_PIN_PER_REG            (16 / DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define DS_0(__B, __P)            (GRF->GPIO##__B##__P##_DS_0)
 | 
				
			||||||
 | 
					#define DS_1(__B, __P)            (GRF->GPIO##__B##__P##_DS_1)
 | 
				
			||||||
 | 
					#define DS_2(__B, __P)            (GRF->GPIO##__B##__P##_DS_2)
 | 
				
			||||||
 | 
					#define DS_3(__B, __P)            (GRF->GPIO##__B##__P##_DS_3)
 | 
				
			||||||
 | 
					#define SET_DS_0(_B, _P, p, v, w) _PINCTRL_WRITE(DS_0(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_DS_1(_B, _P, p, v, w) _PINCTRL_WRITE(DS_1(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_DS_2(_B, _P, p, v, w) _PINCTRL_WRITE(DS_2(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_DS_3(_B, _P, p, v, w) _PINCTRL_WRITE(DS_3(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define RK_SET_DS_0(B, P, p, v)   SET_DS_0(B, P, p % DS_PIN_PER_REG, v, DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_DS_1(B, P, p, v)   SET_DS_1(B, P, p % DS_PIN_PER_REG, v, DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_DS_2(B, P, p, v)   SET_DS_2(B, P, p % DS_PIN_PER_REG, v, DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_DS_3(B, P, p, v)   SET_DS_3(B, P, p % DS_PIN_PER_REG, v, DS_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define SET_DS(_GPIO, _PORT, pin, val)       \
 | 
				
			||||||
 | 
					{                                            \
 | 
				
			||||||
 | 
					    if ((pin % 8) < 2) {                     \
 | 
				
			||||||
 | 
					        RK_SET_DS_0(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else if ((pin % 8) < 4) {              \
 | 
				
			||||||
 | 
					        RK_SET_DS_1(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else if ((pin % 8) < 6) {              \
 | 
				
			||||||
 | 
					        RK_SET_DS_2(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else {                                 \
 | 
				
			||||||
 | 
					        RK_SET_DS_3(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    }                                        \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(GRF_GPIO0A_P_OFFSET)
 | 
				
			||||||
 | 
					#define P_BIT_PER_PIN                 (2)
 | 
				
			||||||
 | 
					#define P_PIN_PER_REG                 (16 / P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define P_0(__B, __P)                 (GRF->GPIO##__B##__P##_P)
 | 
				
			||||||
 | 
					#define SET_P_0(_B, _P, p, v, w)      _PINCTRL_WRITE(P_0(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define RK_SET_P_0(B, P, p, v)        SET_P_0(B, P, p % P_PIN_PER_REG, v, P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define SET_P(_GPIO, _PORT, pin, val) RK_SET_P_0(_GPIO, _PORT, pin, val)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#elif defined(GRF_GPIO0A_P_H_OFFSET)
 | 
				
			||||||
 | 
					#define P_BIT_PER_PIN            (4)
 | 
				
			||||||
 | 
					#define P_PIN_PER_REG            (16 / P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define P_0(__B, __P)            (GRF->GPIO##__B##__P##_P_L)
 | 
				
			||||||
 | 
					#define P_1(__B, __P)            (GRF->GPIO##__B##__P##_P_L)
 | 
				
			||||||
 | 
					#define SET_P_0(_B, _P, p, v, w) _PINCTRL_WRITE(P_0(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_P_1(_B, _P, p, v, w) _PINCTRL_WRITE(P_1(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define RK_SET_P_0(B, P, p, v)   SET_P_0(B, P, p % P_PIN_PER_REG, v, P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_P_1(B, P, p, v)   SET_P_1(B, P, p % P_PIN_PER_REG, v, P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define SET_P(_GPIO, _PORT, pin, val)       \
 | 
				
			||||||
 | 
					{                                           \
 | 
				
			||||||
 | 
					    if ((pin % 8) < 4) {                    \
 | 
				
			||||||
 | 
					        RK_SET_P_0(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else {                                \
 | 
				
			||||||
 | 
					        RK_SET_P_3(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    }                                       \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#elif defined(GRF_GPIO0A_P_0_OFFSET)
 | 
				
			||||||
 | 
					#define P_BIT_PER_PIN            (8)
 | 
				
			||||||
 | 
					#define P_PIN_PER_REG            (16 / P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define P_0(__B, __P)            (GRF->GPIO##__B##__P##_P_0)
 | 
				
			||||||
 | 
					#define P_1(__B, __P)            (GRF->GPIO##__B##__P##_P_1)
 | 
				
			||||||
 | 
					#define P_2(__B, __P)            (GRF->GPIO##__B##__P##_P_2)
 | 
				
			||||||
 | 
					#define P_3(__B, __P)            (GRF->GPIO##__B##__P##_P_3)
 | 
				
			||||||
 | 
					#define SET_P_0(_B, _P, p, v, w) _PINCTRL_WRITE(P_0(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_P_1(_B, _P, p, v, w) _PINCTRL_WRITE(P_1(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_P_2(_B, _P, p, v, w) _PINCTRL_WRITE(P_2(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define SET_P_3(_B, _P, p, v, w) _PINCTRL_WRITE(P_3(_B, _P), RK_GEN_VAL(p, v, w))
 | 
				
			||||||
 | 
					#define RK_SET_P_0(B, P, p, v)   SET_P_0(B, P, p % P_PIN_PER_REG, v, P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_P_1(B, P, p, v)   SET_P_1(B, P, p % P_PIN_PER_REG, v, P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_P_2(B, P, p, v)   SET_P_2(B, P, p % P_PIN_PER_REG, v, P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define RK_SET_P_3(B, P, p, v)   SET_P_3(B, P, p % P_PIN_PER_REG, v, P_BIT_PER_PIN)
 | 
				
			||||||
 | 
					#define SET_P(_GPIO, _PORT, pin, val)       \
 | 
				
			||||||
 | 
					{                                           \
 | 
				
			||||||
 | 
					    if ((pin % 8) < 2) {                    \
 | 
				
			||||||
 | 
					        RK_SET_P_0(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else if ((pin % 8) < 4) {             \
 | 
				
			||||||
 | 
					        RK_SET_P_1(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else if ((pin % 8) < 6) {             \
 | 
				
			||||||
 | 
					        RK_SET_P_2(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    } else {                                \
 | 
				
			||||||
 | 
					        RK_SET_P_3(_GPIO, _PORT, pin, val); \
 | 
				
			||||||
 | 
					    }                                       \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SET_IOMUX
 | 
				
			||||||
 | 
					#define PINCTRL_SET_IOMUX(bank, pin, val) \
 | 
				
			||||||
 | 
					{                                         \
 | 
				
			||||||
 | 
					    if (pin < 8) {                        \
 | 
				
			||||||
 | 
					        SET_IOMUX(bank, A, pin, val);     \
 | 
				
			||||||
 | 
					    } else if (pin < 16) {                \
 | 
				
			||||||
 | 
					        SET_IOMUX(bank, B, pin, val);     \
 | 
				
			||||||
 | 
					    } else if (pin < 24) {                \
 | 
				
			||||||
 | 
					        SET_IOMUX(bank, C, pin, val);     \
 | 
				
			||||||
 | 
					    } else {                              \
 | 
				
			||||||
 | 
					        SET_IOMUX(bank, D, pin, val);     \
 | 
				
			||||||
 | 
					    }                                     \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SET_DS
 | 
				
			||||||
 | 
					#define PINCTRL_SET_DS(bank, pin, val) \
 | 
				
			||||||
 | 
					{                                      \
 | 
				
			||||||
 | 
					    if (pin < 8) {                     \
 | 
				
			||||||
 | 
					        SET_DS(bank, A, pin, val);     \
 | 
				
			||||||
 | 
					    } else if (pin < 16) {             \
 | 
				
			||||||
 | 
					        SET_DS(bank, B, pin, val);     \
 | 
				
			||||||
 | 
					    } else if (pin < 24) {             \
 | 
				
			||||||
 | 
					        SET_DS(bank, C, pin, val);     \
 | 
				
			||||||
 | 
					    } else {                           \
 | 
				
			||||||
 | 
					        SET_DS(bank, D, pin, val);     \
 | 
				
			||||||
 | 
					    }                                  \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SET_P
 | 
				
			||||||
 | 
					#define PINCTRL_SET_P(bank, pin, val) \
 | 
				
			||||||
 | 
					{                                     \
 | 
				
			||||||
 | 
					    if (pin < 8) {                    \
 | 
				
			||||||
 | 
					        SET_P(bank, A, pin, val);     \
 | 
				
			||||||
 | 
					    } else if (pin < 16) {            \
 | 
				
			||||||
 | 
					        SET_P(bank, B, pin, val);     \
 | 
				
			||||||
 | 
					    } else if (pin < 24) {            \
 | 
				
			||||||
 | 
					        SET_P(bank, C, pin, val);     \
 | 
				
			||||||
 | 
					    } else {                          \
 | 
				
			||||||
 | 
					        SET_P(bank, D, pin, val);     \
 | 
				
			||||||
 | 
					    }                                 \
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Variable Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Function Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Private function to set iomux for one pin.
 | 
				
			||||||
 | 
					 * @param  bank: pin bank channel.
 | 
				
			||||||
 | 
					 * @param  pin: pin index, 0~31.
 | 
				
			||||||
 | 
					 * @param  param: value to write.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static HAL_Status PINCTRL_SetIOMUX(eGPIO_bankId bank, uint8_t pin, uint32_t data)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#ifdef PINCTRL_SET_IOMUX
 | 
				
			||||||
 | 
					    switch (bank) {
 | 
				
			||||||
 | 
					#ifdef GPIO0
 | 
				
			||||||
 | 
					    case 0:
 | 
				
			||||||
 | 
					        PINCTRL_SET_IOMUX(0, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO1
 | 
				
			||||||
 | 
					    case 1:
 | 
				
			||||||
 | 
					        PINCTRL_SET_IOMUX(1, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO2
 | 
				
			||||||
 | 
					    case 2:
 | 
				
			||||||
 | 
					        PINCTRL_SET_IOMUX(2, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO3
 | 
				
			||||||
 | 
					    case 3:
 | 
				
			||||||
 | 
					        PINCTRL_SET_IOMUX(3, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO4
 | 
				
			||||||
 | 
					    case 4:
 | 
				
			||||||
 | 
					    #ifdef SOC_RV1126
 | 
				
			||||||
 | 
					        if (pin < 2) {
 | 
				
			||||||
 | 
					            GRF->GPIO4A_IOMUX_L = RK_GEN_VAL(pin % IOMUX_PIN_PER_REG, data, IOMUX_BIT_PER_PIN);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    #else
 | 
				
			||||||
 | 
					        PINCTRL_SET_IOMUX(4, pin, data);
 | 
				
			||||||
 | 
					    #endif
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					    default:
 | 
				
			||||||
 | 
					        HAL_DBG("unknown gpio%d\n", bank);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_ERROR;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Private function to set drive strength for one pin.
 | 
				
			||||||
 | 
					 * @param  bank: pin bank channel.
 | 
				
			||||||
 | 
					 * @param  pin: pin index, 0~31.
 | 
				
			||||||
 | 
					 * @param  param: value to write.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static HAL_Status PINCTRL_SetDS(eGPIO_bankId bank, uint8_t pin, uint32_t data)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#ifdef PINCTRL_SET_DS
 | 
				
			||||||
 | 
					    switch (bank) {
 | 
				
			||||||
 | 
					#ifdef GPIO0
 | 
				
			||||||
 | 
					    case 0:
 | 
				
			||||||
 | 
					        PINCTRL_SET_DS(0, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO1
 | 
				
			||||||
 | 
					    case 1:
 | 
				
			||||||
 | 
					        PINCTRL_SET_DS(1, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO2
 | 
				
			||||||
 | 
					    case 2:
 | 
				
			||||||
 | 
					        PINCTRL_SET_DS(2, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO3
 | 
				
			||||||
 | 
					    case 3:
 | 
				
			||||||
 | 
					        PINCTRL_SET_DS(3, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO4
 | 
				
			||||||
 | 
					    case 4:
 | 
				
			||||||
 | 
					    #ifdef SOC_RV1126
 | 
				
			||||||
 | 
					        if (pin < 2) {
 | 
				
			||||||
 | 
					            GRF->GPIO4A_DS_L = RK_GEN_VAL(pin % DS_PIN_PER_REG, data, DS_BIT_PER_PIN);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    #else
 | 
				
			||||||
 | 
					        PINCTRL_SET_DS(4, pin, data);
 | 
				
			||||||
 | 
					    #endif
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					    default:
 | 
				
			||||||
 | 
					        HAL_DBG("unknown gpio%d\n", bank);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_ERROR;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Private function to set pupd for one pin.
 | 
				
			||||||
 | 
					 * @param  bank: pin bank channel.
 | 
				
			||||||
 | 
					 * @param  pin: pin index, 0~31.
 | 
				
			||||||
 | 
					 * @param  param: value to write.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static HAL_Status PINCTRL_SetPUPD(eGPIO_bankId bank, uint8_t pin, uint32_t data)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					#ifdef PINCTRL_SET_P
 | 
				
			||||||
 | 
					    switch (bank) {
 | 
				
			||||||
 | 
					#ifdef GPIO0
 | 
				
			||||||
 | 
					    case 0:
 | 
				
			||||||
 | 
					    #ifdef SOC_RV1126
 | 
				
			||||||
 | 
					        if (pin < 8) {
 | 
				
			||||||
 | 
					            SET_P(0, A, pin, data);
 | 
				
			||||||
 | 
					        } else if (pin < 16) {
 | 
				
			||||||
 | 
					            SET_P(0, B, pin, data);
 | 
				
			||||||
 | 
					        } else if (pin < 20) {
 | 
				
			||||||
 | 
					            GRF->GPIO0C_P_L = RK_GEN_VAL(pin % P_PIN_PER_REG, data, P_BIT_PER_PIN);
 | 
				
			||||||
 | 
					        } else if (pin < 24) {
 | 
				
			||||||
 | 
					            GRF->GPIO0C_P_H = RK_GEN_VAL(pin % P_PIN_PER_REG, data, P_BIT_PER_PIN);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            SET_P(0, D, pin, data);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    #else
 | 
				
			||||||
 | 
					        PINCTRL_SET_P(0, pin, data);
 | 
				
			||||||
 | 
					    #endif
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO1
 | 
				
			||||||
 | 
					    case 1:
 | 
				
			||||||
 | 
					        PINCTRL_SET_P(1, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO2
 | 
				
			||||||
 | 
					    case 2:
 | 
				
			||||||
 | 
					        PINCTRL_SET_P(2, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO3
 | 
				
			||||||
 | 
					    case 3:
 | 
				
			||||||
 | 
					        PINCTRL_SET_P(3, pin, data);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO4
 | 
				
			||||||
 | 
					    case 4:
 | 
				
			||||||
 | 
					        #ifdef SOC_RV1126
 | 
				
			||||||
 | 
					        if (pin < 2) {
 | 
				
			||||||
 | 
					            GRF->GPIO4A_P = RK_GEN_VAL(pin % P_PIN_PER_REG, data, P_BIT_PER_PIN);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        #else
 | 
				
			||||||
 | 
					        PINCTRL_SET_P(4, pin, data);
 | 
				
			||||||
 | 
					        #endif
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					    default:
 | 
				
			||||||
 | 
					        HAL_DBG("unknown gpio%d\n", bank);
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_ERROR;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Private function to configure one pin.
 | 
				
			||||||
 | 
					 * @param  bank: pin bank channel defined in @ref eGPIO_bankId.
 | 
				
			||||||
 | 
					 * @param  pin: pin index, 0~31.
 | 
				
			||||||
 | 
					 * @param  param: multi params defined in @ref ePINCTRL_configParam,
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static HAL_Status PINCTRL_SetPinParam(eGPIO_bankId bank, uint8_t pin, uint32_t param)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_Status rc = HAL_OK;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (param & FLAG_MUX) {
 | 
				
			||||||
 | 
					        rc |= PINCTRL_SetIOMUX(bank, pin, (uint8_t)((param & MASK_MUX) >> SHIFT_MUX));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (param & FLAG_PUL) {
 | 
				
			||||||
 | 
					        rc |= PINCTRL_SetPUPD(bank, pin, (uint8_t)((param & MASK_PUL) >> SHIFT_PUL));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (param & FLAG_DRV) {
 | 
				
			||||||
 | 
					        rc |= PINCTRL_SetDS(bank, pin, (uint8_t)((param & MASK_DRV) >> SHIFT_DRV));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return rc;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Public Function Definition ****************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup PINCTRL_Exported_Functions_Group1 Suspend and Resume Functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 This section provides functions allowing to suspend and resume the module:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup PINCTRL_Exported_Functions_Group2 Init and DeInit Functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 This section provides functions allowing to init and deinit the module:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_Init(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_DeInit(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup PINCTRL_Exported_Functions_Group3 IO Functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Public function to configure for multi pins.
 | 
				
			||||||
 | 
					 * @param  bank: pin bank channel defined in eGPIO_bankId.
 | 
				
			||||||
 | 
					 * @param  mPins: multi pins defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @param  param: multi params defined in @ref ePINCTRL_configParam.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_SetParam(eGPIO_bankId bank, uint32_t mPins, ePINCTRL_configParam param)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint8_t pin;
 | 
				
			||||||
 | 
					    HAL_Status rc;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_ASSERT(bank < GPIO_BANK_NUM);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!(param & (FLAG_MUX | FLAG_PUL | FLAG_DRV | FLAG_SRT | FLAG_SMT))) {
 | 
				
			||||||
 | 
					        return HAL_OK;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for (pin = 0; pin < 32; pin++) {
 | 
				
			||||||
 | 
					        if (mPins & (1 << pin)) {
 | 
				
			||||||
 | 
					            rc = PINCTRL_SetPinParam(bank, pin, param);
 | 
				
			||||||
 | 
					            if (rc) {
 | 
				
			||||||
 | 
					                return rc;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Public function to set iomux for multi pins.
 | 
				
			||||||
 | 
					 * @param  bank: pin bank channel defined in eGPIO_bankId.
 | 
				
			||||||
 | 
					 * @param  mPins: multi pins defined in @ref ePINCTRL_GPIO_PINS.
 | 
				
			||||||
 | 
					 * @param  param: multi params defined in @ref ePINCTRL_configParam.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_SetIOMUX(eGPIO_bankId bank, uint32_t mPins, ePINCTRL_configParam param)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return HAL_PINCTRL_SetParam(bank, mPins, param);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,306 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_base.h"
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					#include "hal_timer.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup TIMER
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup TIMER_How_To_Use How To Use
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 The TIMER driver can be used as follows:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 - IT mode: Resgister TIMER handler.
 | 
				
			||||||
 | 
					 - Initialize the TIMER by calling HAL_TIMER_Init():
 | 
				
			||||||
 | 
					 - Set TIMER count by calling HAL_TIMER_SetCount().
 | 
				
			||||||
 | 
					 - Start the TIMER by calling HAL_TIMER_Start() or HAL_TIMER_Start_IT().
 | 
				
			||||||
 | 
					 - Stop the TIMER by calling HAL_TIMER_Stop() or HAL_TIMER_Stop_IT().
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 SYS_TIMER
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 - SYS_TIMER is a rk timer fixed to serve the delay system. Invoke HAL_TIMER_SysTimerInit() to init.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup TIMER_Private_Definition Private Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/********************* Private MACRO Definition ******************************/
 | 
				
			||||||
 | 
					#define TIMER_CONTROLREG_TIMER_MODE_FREE_RUNNING (0x0U << TIMER_CONTROLREG_TIMER_MODE_SHIFT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define TIMER_CONTROLREG_TIMER_ENABLE_ENABLED  (0x1U << TIMER_CONTROLREG_TIMER_ENABLE_SHIFT)
 | 
				
			||||||
 | 
					#define TIMER_CONTROLREG_TIMER_ENABLE_DISABLED (0x0U << TIMER_CONTROLREG_TIMER_ENABLE_SHIFT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define TIMER_CONTROLREG_TIMER_INT_MASK_UNMASK (0x1U << TIMER_CONTROLREG_TIMER_INT_MASK_SHIFT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Variable Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Function Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/********************* Public Function Definition ****************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup TIMER_Exported_Functions_Group4 Init and DeInit Functions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 This section provides functions allowing to init and deinit module as follows:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Timer init.
 | 
				
			||||||
 | 
					 * @param  pReg: Choose TIMER.
 | 
				
			||||||
 | 
					 * @param  mode: Choose TIMER mode.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Init(struct TIMER_REG *pReg, eTIMER_MODE mode)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					#ifdef SYS_TIMER
 | 
				
			||||||
 | 
					    if (pReg == SYS_TIMER) {
 | 
				
			||||||
 | 
					        return HAL_BUSY;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    WRITE_REG(pReg->CONTROLREG, mode << TIMER_CONTROLREG_TIMER_MODE_SHIFT);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  System Timer init.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 * @attention this API allow direct use in the HAL layer. SYS_TTIMER is used for delay system.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_SysTimerInit(struct TIMER_REG *pReg)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (READ_BIT(pReg->CONTROLREG, TIMER_CONTROLREG_TIMER_ENABLE_MASK)) {
 | 
				
			||||||
 | 
					        return HAL_OK;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    WRITE_REG(pReg->CONTROLREG, TIMER_FREE_RUNNING);
 | 
				
			||||||
 | 
					    pReg->LOAD_COUNT[0] = 0xFFFFFFFFU;
 | 
				
			||||||
 | 
					    pReg->LOAD_COUNT[1] = 0xFFFFFFFFU;
 | 
				
			||||||
 | 
					    CLEAR_BIT(pReg->CONTROLREG, TIMER_CONTROLREG_TIMER_INT_MASK_MASK);
 | 
				
			||||||
 | 
					    SET_BIT(pReg->CONTROLREG, TIMER_CONTROLREG_TIMER_ENABLE_MASK);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Timer deinit.
 | 
				
			||||||
 | 
					 * @param  pReg: Choose TIMER.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_DeInit(struct TIMER_REG *pReg)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					#ifdef SYS_TIMER
 | 
				
			||||||
 | 
					    if (pReg == SYS_TIMER) {
 | 
				
			||||||
 | 
					        return HAL_BUSY;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    WRITE_REG(pReg->CONTROLREG, 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup TIMER_Exported_Functions_Group5 Other Functions
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Start TIMER counter.
 | 
				
			||||||
 | 
					 * @param  pReg: Choose TIMER.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Start(struct TIMER_REG *pReg)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					#ifdef SYS_TIMER
 | 
				
			||||||
 | 
					    if (pReg == SYS_TIMER) {
 | 
				
			||||||
 | 
					        return HAL_BUSY;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    CLEAR_BIT(pReg->CONTROLREG, TIMER_CONTROLREG_TIMER_INT_MASK_MASK);
 | 
				
			||||||
 | 
					    SET_BIT(pReg->CONTROLREG, TIMER_CONTROLREG_TIMER_ENABLE_MASK);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Stop TIMER counter.
 | 
				
			||||||
 | 
					 * @param  pReg: Choose TIMER.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 * Just disable TIMER, and keep TIMER configuration.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Stop(struct TIMER_REG *pReg)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					#ifdef SYS_TIMER
 | 
				
			||||||
 | 
					    if (pReg == SYS_TIMER) {
 | 
				
			||||||
 | 
					        return HAL_BUSY;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    CLEAR_BIT(pReg->CONTROLREG, TIMER_CONTROLREG_TIMER_ENABLE_MASK);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Start TIMER counter in interrupt mode.
 | 
				
			||||||
 | 
					 * @param  pReg: Choose TIMER.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Start_IT(struct TIMER_REG *pReg)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					#ifdef SYS_TIMER
 | 
				
			||||||
 | 
					    if (pReg == SYS_TIMER) {
 | 
				
			||||||
 | 
					        return HAL_BUSY;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    SET_BIT(pReg->CONTROLREG, TIMER_CONTROLREG_TIMER_ENABLE_ENABLED | TIMER_CONTROLREG_TIMER_INT_MASK_UNMASK);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Stop TIMER counter in interrupt mode.
 | 
				
			||||||
 | 
					 * @param  pReg: Choose TIMER.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 * Just disable TIMER, and keep TIMER configuration.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Stop_IT(struct TIMER_REG *pReg)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					#ifdef SYS_TIMER
 | 
				
			||||||
 | 
					    if (pReg == SYS_TIMER) {
 | 
				
			||||||
 | 
					        return HAL_BUSY;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    CLEAR_BIT(pReg->CONTROLREG, TIMER_CONTROLREG_TIMER_ENABLE_MASK);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set TIMER count number.
 | 
				
			||||||
 | 
					 * @param  pReg: Choose TIMER.
 | 
				
			||||||
 | 
					 * @param  timerCount: TIMER counter loading number.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 * Set timer count number.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_SetCount(struct TIMER_REG *pReg, uint64_t timerCount)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint64_t loadCount = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					#ifdef SYS_TIMER
 | 
				
			||||||
 | 
					    if (pReg == SYS_TIMER) {
 | 
				
			||||||
 | 
					        return HAL_BUSY;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    loadCount = timerCount;
 | 
				
			||||||
 | 
					    pReg->LOAD_COUNT[0] = (loadCount & 0xffffffff);
 | 
				
			||||||
 | 
					    pReg->LOAD_COUNT[1] = ((loadCount >> 32) & 0xffffffff);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get TIMER count number.
 | 
				
			||||||
 | 
					 * @param  pReg: Choose TIMER.
 | 
				
			||||||
 | 
					 * @return uint64_t: Current conut number.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_SECTION_SRAM_CODE
 | 
				
			||||||
 | 
					uint64_t HAL_TIMER_GetCount(struct TIMER_REG *pReg)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t high, low, temp;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    do {
 | 
				
			||||||
 | 
					        high = pReg->CURRENT_VALUE[1];
 | 
				
			||||||
 | 
					        low = pReg->CURRENT_VALUE[0];
 | 
				
			||||||
 | 
					        temp = pReg->CURRENT_VALUE[1];
 | 
				
			||||||
 | 
					    } while (high != temp);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return ((uint64_t)high << 32) | low;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Clear TIMER interrupt status.
 | 
				
			||||||
 | 
					 * @param  pReg: Choose TIMER.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_ClrInt(struct TIMER_REG *pReg)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t timeOut = 1000;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_ASSERT(IS_TIMER_INSTANCE(pReg));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    pReg->INTSTATUS = 0x1;
 | 
				
			||||||
 | 
					    while (pReg->INTSTATUS && timeOut) {
 | 
				
			||||||
 | 
					        timeOut--;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (timeOut == 0) {
 | 
				
			||||||
 | 
					        return HAL_TIMEOUT;
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        return HAL_OK;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  TIMER0 interrupt handler.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK.
 | 
				
			||||||
 | 
					 * Clear interrupt status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					__attribute__((weak)) HAL_Status HAL_TIMER0_Handler(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_TIMER_ClrInt(TIMER0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  TIMER1 interrupt handler.
 | 
				
			||||||
 | 
					 * @return HAL_Status: HAL_OK.
 | 
				
			||||||
 | 
					 * Clear interrupt status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					__attribute__((weak)) HAL_Status HAL_TIMER1_Handler(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_TIMER_ClrInt(TIMER1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return HAL_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,800 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_bsp.h"
 | 
				
			||||||
 | 
					#include "hal_base.h"
 | 
				
			||||||
 | 
					#include "hal_gmac.h"
 | 
				
			||||||
 | 
					#include "hal_pinctrl.h"
 | 
				
			||||||
 | 
					#include "hal_debug.h"
 | 
				
			||||||
 | 
					#include "hal_timer.h"
 | 
				
			||||||
 | 
					#include "hal_cache.h"
 | 
				
			||||||
 | 
					#include "hal_gpio.h"
 | 
				
			||||||
 | 
					#include "hal_cru.h"
 | 
				
			||||||
 | 
					#include "libserial.h"
 | 
				
			||||||
 | 
					#include "stdlib.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*************************** GMAC DRIVER ****************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					#define __is_print(ch) ((unsigned int)((ch) - ' ') < 127u - ' ')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CONFIG_SYS_NONCACHED_MEMORY (4 << 20) /* 4M */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* 1MB granularity */
 | 
				
			||||||
 | 
					#define MMU_SECTION_SIZE (1 << 20)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private MACRO Definition ******************************/
 | 
				
			||||||
 | 
					#define GMAC_BUS_MAX 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define ARCH_DMA_MINALIGN 64
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GMAC_DESCRIPTOR_SIZE 16
 | 
				
			||||||
 | 
					#define GMAC_DESCRIPTORS_TX  8
 | 
				
			||||||
 | 
					#define GMAC_DESCRIPTORS_RX  8
 | 
				
			||||||
 | 
					#define GMAC_DESC_TX_SIZE    HAL_GMAC_ALIGN(GMAC_DESCRIPTORS_TX * GMAC_DESCRIPTOR_SIZE, ARCH_DMA_MINALIGN)
 | 
				
			||||||
 | 
					#define GMAC_DESC_RX_SIZE    HAL_GMAC_ALIGN(GMAC_DESCRIPTORS_RX * GMAC_DESCRIPTOR_SIZE, ARCH_DMA_MINALIGN)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GMAC_RX_BUFFER_SIZE (GMAC_DESCRIPTORS_RX * HAL_GMAC_MAX_PACKET_SIZE)
 | 
				
			||||||
 | 
					#define GMAC_TX_BUFFER_SIZE (GMAC_DESCRIPTORS_TX * HAL_GMAC_MAX_PACKET_SIZE)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Basic mode control register. */
 | 
				
			||||||
 | 
					#define BMCR_RESV      0x003f      /* Unused...                   */
 | 
				
			||||||
 | 
					#define BMCR_SPEED1000 0x0040     /* MSB of Speed (1000)         */
 | 
				
			||||||
 | 
					#define BMCR_CTST      0x0080     /* Collision test              */
 | 
				
			||||||
 | 
					#define BMCR_FULLDPLX  0x0100     /* Full duplex                 */
 | 
				
			||||||
 | 
					#define BMCR_ANRESTART 0x0200     /* Auto negotiation restart    */
 | 
				
			||||||
 | 
					#define BMCR_ISOLATE   0x0400     /* Isolate data paths from MII */
 | 
				
			||||||
 | 
					#define BMCR_PDOWN     0x0800     /* Enable low power state      */
 | 
				
			||||||
 | 
					#define BMCR_ANENABLE  0x1000     /* Enable auto negotiation     */
 | 
				
			||||||
 | 
					#define BMCR_SPEED100  0x2000     /* Select 100Mbps              */
 | 
				
			||||||
 | 
					#define BMCR_LOOPBACK  0x4000     /* TXD loopback bits           */
 | 
				
			||||||
 | 
					#define BMCR_RESET     0x8000     /* Reset to default state      */
 | 
				
			||||||
 | 
					#define BMCR_SPEED10   0x0000     /* Select 10Mbps               */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GMAC_TEST_TIMES 1600
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Structure Definition **************************/
 | 
				
			||||||
 | 
					/* GMAC consumer config data. */
 | 
				
			||||||
 | 
					struct GMAC_ETH_CONFIG {
 | 
				
			||||||
 | 
					    struct GMAC_HANDLE instance;
 | 
				
			||||||
 | 
					    const struct HAL_GMAC_DEV *halDev;
 | 
				
			||||||
 | 
					    eGMAC_PHY_Interface mode;
 | 
				
			||||||
 | 
					    uint32_t speed;
 | 
				
			||||||
 | 
					    uint32_t maxSpeed;
 | 
				
			||||||
 | 
					    uint16_t phyAddr;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    bool extClk;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* phy reset gpio */
 | 
				
			||||||
 | 
					    struct GPIO_REG *resetGpioBank;
 | 
				
			||||||
 | 
					    ePINCTRL_GPIO_PINS resetGpioNum;
 | 
				
			||||||
 | 
					    uint32_t resetDelayMs[3];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    int32_t txDelay;
 | 
				
			||||||
 | 
					    int32_t rxDelay;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    struct GMAC_Desc *txDescs;
 | 
				
			||||||
 | 
					    struct GMAC_Desc *rxDescs;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    uint8_t *txBuff;
 | 
				
			||||||
 | 
					    uint8_t *rxBuff;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* MAC address info, hw address */
 | 
				
			||||||
 | 
					    uint8_t macAddr[6];
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Variable Definition ***************************/
 | 
				
			||||||
 | 
					#ifdef NC_MEM_BASE
 | 
				
			||||||
 | 
					static const unsigned long os_no_cache_start = (unsigned long)NC_MEM_BASE;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					static const unsigned long os_no_cache_start = 0;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Reserve one MMU section worth of address space below the malloc() area that
 | 
				
			||||||
 | 
					 * will be mapped uncached.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static unsigned long noncached_start;
 | 
				
			||||||
 | 
					static unsigned long noncached_end;
 | 
				
			||||||
 | 
					static unsigned long noncached_next;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static unsigned int m_nocachemem_inited = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static uint8_t dstAddr[6] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static struct GMAC_ETH_CONFIG ethConfigTable[] =
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        .halDev = &g_gmac0Dev,
 | 
				
			||||||
 | 
					        .mode = PHY_INTERFACE_MODE_RGMII,
 | 
				
			||||||
 | 
					        .maxSpeed = 1000,
 | 
				
			||||||
 | 
					        .phyAddr = 1,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        .extClk = false,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        .resetGpioBank = GPIO2,
 | 
				
			||||||
 | 
					        .resetGpioNum = GPIO_PIN_D3,
 | 
				
			||||||
 | 
					        .resetDelayMs = { 0, 20, 100 },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        .txDelay = 0x3C,
 | 
				
			||||||
 | 
					        .rxDelay = 0x2f,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // {
 | 
				
			||||||
 | 
					    //     .halDev = &g_gmac1Dev,
 | 
				
			||||||
 | 
					    //     .mode = PHY_INTERFACE_MODE_RGMII,
 | 
				
			||||||
 | 
					    //     .maxSpeed = 1000,
 | 
				
			||||||
 | 
					    //     .phyAddr = 1,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //     .extClk = false,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //     .resetGpioBank = GPIO2,
 | 
				
			||||||
 | 
					    //     .resetGpioNum = GPIO_PIN_D1,
 | 
				
			||||||
 | 
					    //     .resetDelayMs = { 0, 20, 100 },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //     .txDelay = 0x4f,
 | 
				
			||||||
 | 
					    //     .rxDelay = 0x26,
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Private Function Definition ***************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void Dump_Hex(char *message, uint8_t *ptr, uint16_t buflen)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    unsigned char *buf = (unsigned char *)ptr;
 | 
				
			||||||
 | 
					    int i, j;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    printf("%s package at %p, len: %d: \n", message, ptr, buflen);
 | 
				
			||||||
 | 
					    for (i = 0; i < buflen; i += 16) {
 | 
				
			||||||
 | 
					        printf("%08X: ", i);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (j = 0; j < 16; j++) {
 | 
				
			||||||
 | 
					            if (i + j < buflen) {
 | 
				
			||||||
 | 
					                printf("%02X ", buf[i + j]);
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                printf("   ");
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        printf(" ");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (j = 0; j < 16; j++) {
 | 
				
			||||||
 | 
					            if (i + j < buflen) {
 | 
				
			||||||
 | 
					                printf("%c", __is_print(buf[i + j]) ? buf[i + j] : '.');
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        printf("\n");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void print_desc(struct GMAC_HANDLE *pGMAC)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    struct GMAC_Desc *desc;
 | 
				
			||||||
 | 
					    int nIndex;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    printf("\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (pGMAC->rxDescs) {
 | 
				
			||||||
 | 
					        desc = pGMAC->rxDescs;
 | 
				
			||||||
 | 
					        for (nIndex = 0; nIndex < pGMAC->rxSize; nIndex++) {
 | 
				
			||||||
 | 
					            desc = pGMAC->rxDescs + nIndex;
 | 
				
			||||||
 | 
					            printf("rx_desc[%d]@0x%08lx={0x%lx, 0x%lx, 0x%lx, 0x%lx};\n",
 | 
				
			||||||
 | 
					                   nIndex, (uint32_t)desc, desc->des0, desc->des1, desc->des2, desc->des3);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (pGMAC->txDescs) {
 | 
				
			||||||
 | 
					        desc = pGMAC->txDescs;
 | 
				
			||||||
 | 
					        for (nIndex = 0; nIndex < pGMAC->txSize; nIndex++) {
 | 
				
			||||||
 | 
					            desc = pGMAC->txDescs + nIndex;
 | 
				
			||||||
 | 
					            printf("tx_desc[%d]@0x%08lx={0x%lx, 0x%lx, 0x%lx, 0x%lx};\n",
 | 
				
			||||||
 | 
					                   nIndex, (uint32_t)desc, desc->des0, desc->des1, desc->des2, desc->des3);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void Dump_Regs(struct GMAC_HANDLE *pGMAC)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t *reg = (uint32_t *)pGMAC->pReg;
 | 
				
			||||||
 | 
					    int i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    printf("\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for (i = 0; i < (0x200 / 0x4); i++) {
 | 
				
			||||||
 | 
					        printf("offset_0x%08x: %08lx %08lx %08lx %08lx\n", i * 0x10,
 | 
				
			||||||
 | 
					               *((volatile const uint32_t *)(reg + 0x4 * i)), *(volatile const uint32_t *)((reg + 0x4 * i + 1)),
 | 
				
			||||||
 | 
					               *((volatile const uint32_t *)(reg + 0x4 * i + 2)), *((volatile const uint32_t *)(reg + 0x4 * i + 3)));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    reg = reg + 0x1000 / 4;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for (i = 0; i < (0x100 / 0x4); i++) {
 | 
				
			||||||
 | 
					        printf("offset_0x%08x: %08lx %08lx %08lx %08lx\n", i * 0x10 + 0x1000,
 | 
				
			||||||
 | 
					               *((volatile const uint32_t *)(reg + 0x4 * i)), *((volatile const uint32_t *)(reg + 0x4 * i + 1)),
 | 
				
			||||||
 | 
					               *((volatile const uint32_t *)(reg + 0x4 * i + 2)), *((volatile const uint32_t *)(reg + 0x4 * i + 3)));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void PHY_Read(struct GMAC_HANDLE *pGMAC, uint32_t phyReg)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    int data;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    data = HAL_GMAC_MDIORead(pGMAC, pGMAC->phyConfig.phyAddress, phyReg);
 | 
				
			||||||
 | 
					    if (data >= 0) {
 | 
				
			||||||
 | 
					        printf("PHY_Read: %02lX --> %08X\n", phyReg, data);
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        printf("PHY_Read: %02lX --> faild\n", phyReg);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void PHY_Write(uint32_t phyReg, uint32_t data)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    struct GMAC_HANDLE *pGMAC;
 | 
				
			||||||
 | 
					    int status;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    status = HAL_GMAC_MDIOWrite(pGMAC, pGMAC->phyConfig.phyAddress, phyReg, data);
 | 
				
			||||||
 | 
					    if (!status) {
 | 
				
			||||||
 | 
					        printf("PHY_Write: %02lX --> %08lX\n", phyReg, data);
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        printf("PHY_Write: %02lX --> faild\n", phyReg);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void PHY_Dump(struct GMAC_ETH_CONFIG *eth, struct GMAC_HANDLE *pGMAC)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    int data, i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for (i = 0; i < 32; i++) {
 | 
				
			||||||
 | 
					        data = HAL_GMAC_MDIORead(pGMAC, eth->phyAddr, i);
 | 
				
			||||||
 | 
					        if (data < 0) {
 | 
				
			||||||
 | 
					            printf("phy_dump: %d --> faild\n", i);
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (i % 8 == 7) {
 | 
				
			||||||
 | 
					            printf("%d --> %08X\n ", i, data);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            printf("%d --> %08X\n\n", i, data);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    printf("\n");
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void GMAC_PHY_Reset(struct GMAC_ETH_CONFIG *config)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    if (config->resetGpioBank) {
 | 
				
			||||||
 | 
					        HAL_GPIO_SetPinDirection(config->resetGpioBank,
 | 
				
			||||||
 | 
					                                 config->resetGpioNum,
 | 
				
			||||||
 | 
					                                 GPIO_OUT);
 | 
				
			||||||
 | 
					        HAL_GPIO_SetPinLevel(config->resetGpioBank,
 | 
				
			||||||
 | 
					                             config->resetGpioNum,
 | 
				
			||||||
 | 
					                             GPIO_HIGH);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        HAL_DelayMs(config->resetDelayMs[0]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        HAL_GPIO_SetPinLevel(config->resetGpioBank,
 | 
				
			||||||
 | 
					                             config->resetGpioNum,
 | 
				
			||||||
 | 
					                             GPIO_LOW);
 | 
				
			||||||
 | 
					        HAL_DelayMs(config->resetDelayMs[1]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        HAL_GPIO_SetPinLevel(config->resetGpioBank,
 | 
				
			||||||
 | 
					                             config->resetGpioNum,
 | 
				
			||||||
 | 
					                             GPIO_HIGH);
 | 
				
			||||||
 | 
					        HAL_DelayMs(config->resetDelayMs[2]);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static inline void NET_Random_ETHAddr(uint8_t *addr)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    unsigned int seed = HAL_TIMER_GetCount(SYS_TIMER) | 0xffffffff;
 | 
				
			||||||
 | 
					    uint8_t i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for (i = 0; i < 6; i++) {
 | 
				
			||||||
 | 
					        addr[i] = 0xae;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    addr[0] &= 0xfe;    /* clear multicast bit */
 | 
				
			||||||
 | 
					    addr[0] |= 0x02;    /* set local assignment bit (IEEE802) */
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static inline void NET_Random_Package(uint8_t *addr, uint16_t len)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    unsigned int seed = HAL_TIMER_GetCount(SYS_TIMER) | 0xffffffff;
 | 
				
			||||||
 | 
					    uint16_t i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for (i = 0; i < len; i++) {
 | 
				
			||||||
 | 
					        addr[i] = 0xae;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void PHY_Update_Links(struct GMAC_ETH_CONFIG *eth, struct GMAC_HANDLE *pGMAC,
 | 
				
			||||||
 | 
					                             uint8_t id)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_Status status;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    status = HAL_GMAC_PHYStartup(pGMAC);
 | 
				
			||||||
 | 
					    if (status) {
 | 
				
			||||||
 | 
					        printf("HAL_PHY_Startup() failed: %d\n", status);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    HAL_DelayMs(7000);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    status = HAL_GMAC_PHYUpdateLink(pGMAC);
 | 
				
			||||||
 | 
					    if (status == HAL_OK) {
 | 
				
			||||||
 | 
					        if (pGMAC->phyStatus.link) {
 | 
				
			||||||
 | 
					            status = HAL_GMAC_PHYParseLink(pGMAC);
 | 
				
			||||||
 | 
					            if (PHY_SPEED_1000M == pGMAC->phyStatus.speed) {
 | 
				
			||||||
 | 
					                printf("Phy%d: 1000M link speed\n", id);
 | 
				
			||||||
 | 
					            } else if (PHY_SPEED_100M == pGMAC->phyStatus.speed) {
 | 
				
			||||||
 | 
					                printf("Phy%d: 100M link speed\n", id);
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                printf("Phy%d: 10M link speed\n", id);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            if (PHY_DUPLEX_HALF == pGMAC->phyStatus.duplex) {
 | 
				
			||||||
 | 
					                printf("Phy%d: half dumplex\n", id);
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                printf("Phy%d: full dumplex\n", id);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            if (pGMAC->phyStatus.pause) {
 | 
				
			||||||
 | 
					                printf("Phy%d: flow control rx/tx\n", id);
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                printf("Phy%d: flow control off\n", id);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            status = HAL_GMAC_AdjustLink(pGMAC, eth->txDelay, eth->rxDelay);
 | 
				
			||||||
 | 
					            if (status != HAL_OK) {
 | 
				
			||||||
 | 
					                printf("HAL_GMAC_AdjustLink() failed: %d\n", status);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            printf("Phy%d: link up.\n", id);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            printf("Phy%d: link down.\n", id);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* interrupt service routine polling */
 | 
				
			||||||
 | 
					static HAL_Status GMAC_ETH_IRQ(struct GMAC_HANDLE *pGMAC)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    HAL_Status status;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* enter interrupt */
 | 
				
			||||||
 | 
					    /* rt_interrupt_enter(); */
 | 
				
			||||||
 | 
					    status = HAL_GMAC_IRQHandler(pGMAC);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (status & DMA_HANLE_RX) {
 | 
				
			||||||
 | 
					        /* a frame has been received */
 | 
				
			||||||
 | 
					        return 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					    /* leave interrupt */
 | 
				
			||||||
 | 
					    /* rt_interrupt_leave(); */
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static HAL_Status noncached_init(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    unsigned long start, end;
 | 
				
			||||||
 | 
					    size_t size;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (os_no_cache_start <= 0) {
 | 
				
			||||||
 | 
						printf("Noncached_init failed, plase defined no cached memort\n");
 | 
				
			||||||
 | 
						return -1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    start = HAL_GMAC_ALIGN(os_no_cache_start, 64);
 | 
				
			||||||
 | 
					    size = HAL_GMAC_ALIGN(CONFIG_SYS_NONCACHED_MEMORY, MMU_SECTION_SIZE);
 | 
				
			||||||
 | 
					    end = start + size;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    noncached_start = start;
 | 
				
			||||||
 | 
					    noncached_end = end;
 | 
				
			||||||
 | 
					    noncached_next = start;
 | 
				
			||||||
 | 
					    m_nocachemem_inited = 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static unsigned long noncached_alloc(size_t size, size_t align)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    if (!m_nocachemem_inited) {
 | 
				
			||||||
 | 
					        if (noncached_init())
 | 
				
			||||||
 | 
						    return (unsigned long)NULL;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    unsigned long next = HAL_GMAC_ALIGN(noncached_next, align);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (next >= noncached_end || (noncached_end - next) < size) {
 | 
				
			||||||
 | 
					        return 0;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    noncached_next = next + size;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return next;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void *malloc_align(size_t size, size_t align)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    void *align_ptr;
 | 
				
			||||||
 | 
					    void *ptr;
 | 
				
			||||||
 | 
					    size_t align_size;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* align the alignment size to 4 byte */
 | 
				
			||||||
 | 
					    align = ((align + 0x03) & ~0x03);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* get total aligned size */
 | 
				
			||||||
 | 
					    align_size = ((size + 0x03) & ~0x03) + align;
 | 
				
			||||||
 | 
					    /* allocate memory block from heap */
 | 
				
			||||||
 | 
					    ptr = malloc(align_size);
 | 
				
			||||||
 | 
					    if (ptr != NULL) {
 | 
				
			||||||
 | 
					        /* the allocated memory block is aligned */
 | 
				
			||||||
 | 
					        if (((uint32_t)ptr & (align - 1)) == 0) {
 | 
				
			||||||
 | 
					            align_ptr = (void *)((uint32_t)ptr + align);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            align_ptr = (void *)(((uint32_t)ptr + (align - 1)) & ~(align - 1));
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* set the pointer before alignment pointer to the real pointer */
 | 
				
			||||||
 | 
					        *((uint32_t *)((uint32_t)align_ptr - sizeof(void *))) = (uint32_t)ptr;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        ptr = align_ptr;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return ptr;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void free_align(void *ptr)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    void *real_ptr;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    real_ptr = (void *)*(uint32_t *)((uint32_t)ptr - sizeof(void *));
 | 
				
			||||||
 | 
					    free(real_ptr);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Public Function Definition ****************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static HAL_Status GMAC_Send_Test(struct GMAC_ETH_CONFIG *eth, struct GMAC_HANDLE *pGMAC,
 | 
				
			||||||
 | 
					                                 uint16_t len)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint8_t *ptr = NULL;
 | 
				
			||||||
 | 
					    HAL_Status status;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!pGMAC->phyStatus.link) {
 | 
				
			||||||
 | 
					        return -1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* Check the frame length. */
 | 
				
			||||||
 | 
					    if (len > HAL_GMAC_MAX_FRAME_SIZE) {
 | 
				
			||||||
 | 
					        return -1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    ptr = (uint8_t *)HAL_GMAC_GetTXBuffer(pGMAC);
 | 
				
			||||||
 | 
					    memcpy(ptr, dstAddr, 6);
 | 
				
			||||||
 | 
					    memcpy(ptr + 6, eth->macAddr, 6);
 | 
				
			||||||
 | 
					    ptr[12] = 0x40;
 | 
				
			||||||
 | 
					    ptr[13] = 0x06;
 | 
				
			||||||
 | 
					    ptr[14] = 0x00;
 | 
				
			||||||
 | 
					    ptr[15] = 0x01;
 | 
				
			||||||
 | 
					    NET_Random_Package(ptr + 16, len - 16);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (len > 60) {
 | 
				
			||||||
 | 
					        /* index */
 | 
				
			||||||
 | 
					        ptr[50] = pGMAC->txDescIdx;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* dump packages */
 | 
				
			||||||
 | 
					    Dump_Hex("Tx", ptr, len);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_DCACHE_CleanByRange((uint32_t)ptr, len);
 | 
				
			||||||
 | 
					    status = HAL_GMAC_Send(pGMAC, ptr, len);
 | 
				
			||||||
 | 
					    if (status) {
 | 
				
			||||||
 | 
					        printf("GMAC send failed: %d\n", status);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return status;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static uint16_t GMAC_Recv_Test(struct GMAC_HANDLE *pGMAC)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint8_t *ptr = NULL;
 | 
				
			||||||
 | 
					    HAL_Status status;
 | 
				
			||||||
 | 
					    int32_t size;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!pGMAC->phyStatus.link) {
 | 
				
			||||||
 | 
					        return -1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    status = GMAC_ETH_IRQ(pGMAC);
 | 
				
			||||||
 | 
					    ptr = HAL_GMAC_Recv(pGMAC, &size);
 | 
				
			||||||
 | 
					    while (status && ptr) {
 | 
				
			||||||
 | 
					        if (size > 0 && ptr) {
 | 
				
			||||||
 | 
					            /* dump packages */
 | 
				
			||||||
 | 
					            Dump_Hex("Rx", ptr, size);
 | 
				
			||||||
 | 
					            HAL_DCACHE_InvalidateByRange((uint32_t)ptr, size);
 | 
				
			||||||
 | 
					            HAL_GMAC_CleanRX(pGMAC);
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            printf("GMAC recv failed: %ld\n", size);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            return -1;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        ptr = HAL_GMAC_Recv(pGMAC, &size);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static HAL_Status GMAC_Memory_Init(struct GMAC_ETH_CONFIG *eth, struct GMAC_HANDLE *pGMAC)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    eth->rxDescs = (struct GMAC_Desc *)noncached_alloc(GMAC_DESC_RX_SIZE, ARCH_DMA_MINALIGN);
 | 
				
			||||||
 | 
					    eth->txDescs = (struct GMAC_Desc *)noncached_alloc(GMAC_DESC_TX_SIZE, ARCH_DMA_MINALIGN);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!eth->rxDescs || !eth->txDescs)
 | 
				
			||||||
 | 
					        return -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    eth->rxBuff = malloc_align(GMAC_RX_BUFFER_SIZE, ARCH_DMA_MINALIGN);
 | 
				
			||||||
 | 
					    eth->txBuff = malloc_align(GMAC_TX_BUFFER_SIZE, ARCH_DMA_MINALIGN);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!eth->rxBuff || !eth->txBuff)
 | 
				
			||||||
 | 
					        return -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    memset(eth->rxDescs, 0, GMAC_DESC_RX_SIZE);
 | 
				
			||||||
 | 
					    memset(eth->txDescs, 0, GMAC_DESC_TX_SIZE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    memset(eth->rxBuff, 0, GMAC_RX_BUFFER_SIZE);
 | 
				
			||||||
 | 
					    HAL_DCACHE_InvalidateByRange((uint32_t)eth->rxBuff, GMAC_RX_BUFFER_SIZE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    memset(eth->txBuff, 0, GMAC_TX_BUFFER_SIZE);
 | 
				
			||||||
 | 
					    HAL_DCACHE_CleanByRange((uint32_t)eth->txBuff, GMAC_TX_BUFFER_SIZE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_GMAC_DMARxDescInit(pGMAC, eth->rxDescs, eth->rxBuff, GMAC_DESCRIPTORS_RX);
 | 
				
			||||||
 | 
					    HAL_GMAC_DMATxDescInit(pGMAC, eth->txDescs, eth->txBuff, GMAC_DESCRIPTORS_TX);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    print_desc(pGMAC);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static HAL_Status GMAC_Init(uint8_t id)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    struct GMAC_ETH_CONFIG *eth;
 | 
				
			||||||
 | 
					    struct GMAC_HANDLE *pGMAC;
 | 
				
			||||||
 | 
					    const struct HAL_GMAC_DEV *gmacDev;
 | 
				
			||||||
 | 
					    struct GMAC_PHY_Config config;
 | 
				
			||||||
 | 
					    eGMAC_PHY_Interface interface;
 | 
				
			||||||
 | 
					    HAL_Status status;
 | 
				
			||||||
 | 
					    uint32_t freq;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_ASSERT(id < GMAC_BUS_MAX);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    eth = ðConfigTable[id];
 | 
				
			||||||
 | 
					    if (!eth) {
 | 
				
			||||||
 | 
					        return HAL_ERROR;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    pGMAC = ð->instance;
 | 
				
			||||||
 | 
					    gmacDev = eth->halDev;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* MAC init */
 | 
				
			||||||
 | 
					    interface = eth->mode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (interface == PHY_INTERFACE_MODE_RGMII) {
 | 
				
			||||||
 | 
					        HAL_CRU_ClkSetFreq(gmacDev->clkID, 125000000);
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        HAL_CRU_ClkSetFreq(gmacDev->clkID, 50000000);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    freq = HAL_CRU_ClkGetFreq(gmacDev->pclkID);
 | 
				
			||||||
 | 
					    HAL_GMAC_Init(pGMAC, gmacDev->pReg, freq, interface, eth->extClk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* PHY Init */
 | 
				
			||||||
 | 
					    config.speed = eth->speed;
 | 
				
			||||||
 | 
					    config.maxSpeed = eth->maxSpeed;
 | 
				
			||||||
 | 
					    config.duplexMode = PHY_DUPLEX_FULL;
 | 
				
			||||||
 | 
					    config.neg = PHY_AUTONEG_ENABLE;
 | 
				
			||||||
 | 
					    config.interface = interface;
 | 
				
			||||||
 | 
					    config.phyAddress = eth->phyAddr;
 | 
				
			||||||
 | 
					    config.features = 0;
 | 
				
			||||||
 | 
					    status = HAL_GMAC_PHYInit(pGMAC, &config);
 | 
				
			||||||
 | 
					    if (status) {
 | 
				
			||||||
 | 
					        printf("HAL_PHY_Init() failed: %d\n", status);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return status;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* MAC Address */
 | 
				
			||||||
 | 
					    NET_Random_ETHAddr(eth->macAddr);
 | 
				
			||||||
 | 
					    HAL_GMAC_WriteHWAddr(ð->instance, eth->macAddr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*************************** GMAC TEST ****************************/
 | 
				
			||||||
 | 
					#define GMAC_MAX_DEVICES 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Config iomux for GMAC0
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static void GMAC0_Iomux_Config(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    /* GMAC0 iomux */
 | 
				
			||||||
 | 
					    HAL_PINCTRL_SetIOMUX(GPIO_BANK2,
 | 
				
			||||||
 | 
					                         GPIO_PIN_B6, /* gmac0_rxd0 */
 | 
				
			||||||
 | 
					                         PIN_CONFIG_MUX_FUNC1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_PINCTRL_SetIOMUX(GPIO_BANK2,
 | 
				
			||||||
 | 
					                         GPIO_PIN_C3 | /* gmac0_mdc */
 | 
				
			||||||
 | 
					                         GPIO_PIN_C4 | /* gmac0_mdio */
 | 
				
			||||||
 | 
					                         GPIO_PIN_C0 | /* gmac0_rxdvcrs */
 | 
				
			||||||
 | 
					                         GPIO_PIN_B7 | /* gmac0_rxd1 */
 | 
				
			||||||
 | 
					                         GPIO_PIN_A3 | /* gmac0_rxd2 */
 | 
				
			||||||
 | 
					                         GPIO_PIN_A4 | /* gmac0_rxd3 */
 | 
				
			||||||
 | 
					                         GPIO_PIN_A6 | /* gmac0_txd2 */
 | 
				
			||||||
 | 
					                         GPIO_PIN_A7 | /* gmac0_txd3 */
 | 
				
			||||||
 | 
					                         GPIO_PIN_A5,  /* gmac0_rxclk */
 | 
				
			||||||
 | 
					                         PIN_CONFIG_MUX_FUNC2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_PINCTRL_SetIOMUX(GPIO_BANK2,
 | 
				
			||||||
 | 
					                         GPIO_PIN_B3 | /* gmac0_txd0 */
 | 
				
			||||||
 | 
					                         GPIO_PIN_B4 | /* gmac0_txd1 */
 | 
				
			||||||
 | 
					                         GPIO_PIN_B5,  /* gmac0_txen */
 | 
				
			||||||
 | 
					                         PIN_CONFIG_MUX_FUNC1 | PIN_CONFIG_DRV_LEVEL2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_PINCTRL_SetIOMUX(GPIO_BANK2,
 | 
				
			||||||
 | 
					                         GPIO_PIN_A7 | /* gmac0_txd3 */
 | 
				
			||||||
 | 
					                         GPIO_PIN_A6,  /* gmac0_txd2 */
 | 
				
			||||||
 | 
					                         PIN_CONFIG_MUX_FUNC2 | PIN_CONFIG_DRV_LEVEL2);
 | 
				
			||||||
 | 
					    HAL_PINCTRL_SetIOMUX(GPIO_BANK2,   /* gmac0_txclk */
 | 
				
			||||||
 | 
					                         GPIO_PIN_B0,
 | 
				
			||||||
 | 
					                         PIN_CONFIG_MUX_FUNC2 | PIN_CONFIG_DRV_LEVEL1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if 0
 | 
				
			||||||
 | 
					    /* io-domian: 1.8v or 3.3v for vccio4 */
 | 
				
			||||||
 | 
						WRITE_REG_MASK_WE(GRF->IO_VSEL0,
 | 
				
			||||||
 | 
						                  GRF_IO_VSEL0_POC_VCCIO4_SEL18_MASK,
 | 
				
			||||||
 | 
						                  (1 << GRF_IO_VSEL0_POC_VCCIO4_SEL18_SHIFT));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						WRITE_REG_MASK_WE(GRF->IO_VSEL1,
 | 
				
			||||||
 | 
						                  GRF_IO_VSEL1_POC_VCCIO4_SEL33_MASK,
 | 
				
			||||||
 | 
						                  (0 << GRF_IO_VSEL1_POC_VCCIO4_SEL33_SHIFT));
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Config iomux for GMAC1
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					// static void GMAC1_M1_Iomux_Config(void)
 | 
				
			||||||
 | 
					// {
 | 
				
			||||||
 | 
					//     /* GMAC1 M1 iomux */
 | 
				
			||||||
 | 
					//     HAL_PINCTRL_SetIOMUX(GPIO_BANK4,
 | 
				
			||||||
 | 
					//                          GPIO_PIN_B6 | /* gmac1_mdcm1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_B7 | /* gmac1_mdiom1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_B1 | /* gmac1_rxdvcrsm1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_A7 | /* gmac1_rxd0m1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_B0 | /* gmac1_rxd1m1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_A1 | /* gmac1_rxd2m1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_A2 | /* gmac1_rxd3m1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_A6 | /* gmac1_txenm1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_A3,  /* gmac1_rxclkm1 */
 | 
				
			||||||
 | 
					//                          PIN_CONFIG_MUX_FUNC3);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//     HAL_PINCTRL_SetIOMUX(GPIO_BANK4,
 | 
				
			||||||
 | 
					//                          GPIO_PIN_A0,  /* gmac1_txd1m1 */
 | 
				
			||||||
 | 
					//                          PIN_CONFIG_MUX_FUNC3 | PIN_CONFIG_DRV_LEVEL3);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//     HAL_PINCTRL_SetIOMUX(GPIO_BANK4,
 | 
				
			||||||
 | 
					//                          GPIO_PIN_A4 | /* gmac1_txd0m1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_A5,  /* gmac1_txd1m1 */
 | 
				
			||||||
 | 
					//                          PIN_CONFIG_MUX_FUNC3 | PIN_CONFIG_DRV_LEVEL2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//     /* GMAC1 M1 iomux */
 | 
				
			||||||
 | 
					//     HAL_PINCTRL_SetIOMUX(GPIO_BANK3,
 | 
				
			||||||
 | 
					//                          GPIO_PIN_D6 | /* gmac1_txd2m1 */
 | 
				
			||||||
 | 
					//                          GPIO_PIN_D7,  /* gmac1_txd3m1 */
 | 
				
			||||||
 | 
					//                          PIN_CONFIG_MUX_FUNC3 | PIN_CONFIG_DRV_LEVEL2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//     HAL_PINCTRL_IOFuncSelForGMAC1(IOFUNC_SEL_M1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// #if 0
 | 
				
			||||||
 | 
					//     /* io-domian: 1.8v or 3.3v for vccio6 */
 | 
				
			||||||
 | 
					//     WRITE_REG_MASK_WE(GRF->IO_VSEL0,
 | 
				
			||||||
 | 
					// 	              GRF_IO_VSEL0_POC_VCCIO6_SEL18_MASK,
 | 
				
			||||||
 | 
					// 	              (1 << GRF_IO_VSEL0_POC_VCCIO6_SEL18_SHIFT));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					//     WRITE_REG_MASK_WE(GRF->IO_VSEL1,
 | 
				
			||||||
 | 
					// 	              GRF_IO_VSEL1_POC_VCCIO6_SEL33_MASK,
 | 
				
			||||||
 | 
					// 	              (0 << GRF_IO_VSEL1_POC_VCCIO6_SEL33_SHIFT));
 | 
				
			||||||
 | 
					// #endif
 | 
				
			||||||
 | 
					// }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void GMAC_Iomux_Config(uint8_t id)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    // if (id == 1) {
 | 
				
			||||||
 | 
					    //     GMAC1_M1_Iomux_Config();
 | 
				
			||||||
 | 
					    // } else if (id == 0) {
 | 
				
			||||||
 | 
					        GMAC0_Iomux_Config();
 | 
				
			||||||
 | 
					    // }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*************************** GMAC TEST MAIN ****************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void main(){
 | 
				
			||||||
 | 
					    struct GMAC_ETH_CONFIG *eth;
 | 
				
			||||||
 | 
					    struct GMAC_HANDLE *pGMAC;
 | 
				
			||||||
 | 
					    int32_t bus, num = 0, i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    HAL_DBG("\n");
 | 
				
			||||||
 | 
					    HAL_DBG("%s\n", __func__);
 | 
				
			||||||
 | 
					    HAL_DBG("    GMAC Test:\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    num = sizeof(ethConfigTable) / sizeof(struct GMAC_ETH_CONFIG);
 | 
				
			||||||
 | 
					    HAL_DBG("    GMAC Num: %ld\n", num);
 | 
				
			||||||
 | 
					    for (bus = 0; bus < num; bus++) {
 | 
				
			||||||
 | 
					        eth = ðConfigTable[bus];
 | 
				
			||||||
 | 
					        if (eth) {
 | 
				
			||||||
 | 
					            pGMAC = ð->instance;
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					            return;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* ionmux */
 | 
				
			||||||
 | 
					        GMAC_Iomux_Config(bus);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        HAL_CRU_ClkEnable(eth->halDev->pclkGateID);
 | 
				
			||||||
 | 
					        HAL_CRU_ClkEnable(eth->halDev->clkGateID);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* Register irq */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* PHY reset */
 | 
				
			||||||
 | 
					        GMAC_PHY_Reset(eth);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* GMAC Init */
 | 
				
			||||||
 | 
					        GMAC_Init(bus);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        GMAC_Memory_Init(eth, pGMAC);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* Enable GMAC and DMA transmission and reception */
 | 
				
			||||||
 | 
					        HAL_GMAC_Start(pGMAC, eth->macAddr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* Update links information */
 | 
				
			||||||
 | 
					        PHY_Update_Links(eth, pGMAC, bus);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /* Dump MAC Regs */
 | 
				
			||||||
 | 
					        Dump_Regs(pGMAC);
 | 
				
			||||||
 | 
					        /* Dump PHY Regs */
 | 
				
			||||||
 | 
					        PHY_Dump(eth, pGMAC);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for (i = 0; i < GMAC_TEST_TIMES; i++) {
 | 
				
			||||||
 | 
					            /* GMAC Send 64 bytes */
 | 
				
			||||||
 | 
					            GMAC_Send_Test(eth, pGMAC, 64);
 | 
				
			||||||
 | 
					            /* GMAC Send 1500 bytes */
 | 
				
			||||||
 | 
					            GMAC_Send_Test(eth, pGMAC, 1500);
 | 
				
			||||||
 | 
					            HAL_DelayMs(1000);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            /* GMAC Recv */
 | 
				
			||||||
 | 
					            GMAC_Recv_Test(pGMAC);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        HAL_CRU_ClkDisable(eth->halDev->pclkGateID);
 | 
				
			||||||
 | 
					        HAL_CRU_ClkDisable(eth->halDev->clkGateID);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        free_align(eth->txBuff);
 | 
				
			||||||
 | 
					        free_align(eth->rxBuff);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,100 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup HAL_BASE
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef _HAL_BASE_H_
 | 
				
			||||||
 | 
					#define _HAL_BASE_H_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "stdint.h"
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					#include "hal_debug.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup HAL_BASE_Exported_Definition_Group1 Basic Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** enter markrom usb upgrade */
 | 
				
			||||||
 | 
					#define SYS_UPGRADE_FLAG (0xEF08A53C)
 | 
				
			||||||
 | 
					/** enter loader usb upgrade */
 | 
				
			||||||
 | 
					#define LDR_UPGRADE_FLAG (0x5242C301)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define IS_TICKFREQ(f) (((f) == HAL_TICK_FREQ_1KHZ)  || ((f) == HAL_TICK_FREQ_100HZ) || ((f) == HAL_TICK_FREQ_10HZ))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    HAL_TICK_FREQ_10HZ    = 100U,    /**< 10 ticks per second, so it's 100ms/tick */
 | 
				
			||||||
 | 
					    HAL_TICK_FREQ_100HZ   = 10U,     /**< 100 ticks per second, so it's 10ms/tick */
 | 
				
			||||||
 | 
					    HAL_TICK_FREQ_1KHZ    = 1U,      /**< 1000 ticks per second, so it's 1ms/tick */
 | 
				
			||||||
 | 
					    HAL_TICK_FREQ_DEFAULT = HAL_TICK_FREQ_1KHZ
 | 
				
			||||||
 | 
					} eHAL_tickFreq;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					/** @defgroup HAL_BASE_Public_Function_Declare Public Function Declare
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_InitTick(uint32_t tickPriority);
 | 
				
			||||||
 | 
					HAL_Status HAL_IncTick(void);
 | 
				
			||||||
 | 
					uint32_t HAL_GetTick(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_SetTickFreq(eHAL_tickFreq freq);
 | 
				
			||||||
 | 
					eHAL_tickFreq HAL_GetTickFreq(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_DelayUs(uint32_t us);
 | 
				
			||||||
 | 
					HAL_Status HAL_DelayMs(uint32_t ms);
 | 
				
			||||||
 | 
					HAL_Status HAL_CPUDelayUs(uint32_t us);
 | 
				
			||||||
 | 
					HAL_Status HAL_SystemCoreClockUpdate(uint32_t hz, eHAL_systickClkSource clkSource);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					uint64_t HAL_DivU64Rem(uint64_t numerator, uint32_t denominator, uint32_t *pRemainder);
 | 
				
			||||||
 | 
					uint64_t HAL_GetSysTimerCount(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************* Public Function Definition ***************************/
 | 
				
			||||||
 | 
					/** @defgroup HAL_BASE_Exported_Functions_Group5 Other Functions
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  uint64_t numerator / uint32_t denominator
 | 
				
			||||||
 | 
					 * @param  numerator
 | 
				
			||||||
 | 
					 * @param  denominator
 | 
				
			||||||
 | 
					 * @return uint64_t result
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static inline uint64_t HAL_DivU64(uint64_t numerator, uint32_t denominator)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return HAL_DivU64Rem(numerator, denominator, NULL);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  uint32_t numerator / uint32_t denominator rounded to nearest integer
 | 
				
			||||||
 | 
					 * @param  numerator
 | 
				
			||||||
 | 
					 * @param  denominator
 | 
				
			||||||
 | 
					 * @return uint32_t result rounded to nearest integer
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static inline uint32_t HAL_DivRoundClosest(uint32_t numerator, uint32_t denominator)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return (numerator + (denominator / 2)) / denominator;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,22 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __BSP_H__
 | 
				
			||||||
 | 
					#define __BSP_H__
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_base.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SYS_TIMER TIMER5
 | 
				
			||||||
 | 
					extern const struct HAL_GMAC_DEV g_gmac0Dev;
 | 
				
			||||||
 | 
					extern const struct HAL_GMAC_DEV g_gmac1Dev;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					void BSP_Init(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,87 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup CACHE
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef _HAL_CACHE_H_
 | 
				
			||||||
 | 
					#define _HAL_CACHE_H_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					#include "hal_debug.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					/** @defgroup CACHE_Exported_Definition_Group1 Basic Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 *  performance measurement count for icache & dcache
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					struct CACHE_PMU_CNT {
 | 
				
			||||||
 | 
					    uint32_t rdNum; /**< PMU read number counter */
 | 
				
			||||||
 | 
					    uint32_t wrNum; /**< PMU write number counter */
 | 
				
			||||||
 | 
					    uint32_t sramRdHit; /**< PMU SRAM hit counter */
 | 
				
			||||||
 | 
					    uint32_t hbRdHit; /**< PMU hot buffer hit */
 | 
				
			||||||
 | 
					    uint32_t stbRdHit; /**< PMU store buffer hit */
 | 
				
			||||||
 | 
					    uint32_t rdHit; /**< PMU read hit counter */
 | 
				
			||||||
 | 
					    uint32_t wrHit; /**< PMU write hit counter */
 | 
				
			||||||
 | 
					    uint32_t rdMissPenalty; /**< PMU read miss penalty counter */
 | 
				
			||||||
 | 
					    uint32_t wrMissPenalty; /**< PMU write miss penalty counter */
 | 
				
			||||||
 | 
					    uint32_t rdLat; /**< PMU read latency */
 | 
				
			||||||
 | 
					    uint32_t wrLat; /**< PMU write latency */
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/********************* Public Function Definition ****************************/
 | 
				
			||||||
 | 
					/** @defgroup CACHE_Exported_Functions_Group5 Other Functions
 | 
				
			||||||
 | 
					 *  @attention these APIs allow direct use in the HAL layer
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					uint32_t HAL_CpuAddrToDmaAddr(uint32_t cpuAddr);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_Enable(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_Disable(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_Invalidate(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_InvalidateByRange(uint32_t address, uint32_t sizeByte);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_EnablePMU(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_DisablePMU(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_GetPMU(struct CACHE_PMU_CNT *stat);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_EnableInt(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_DisableInt(void);
 | 
				
			||||||
 | 
					HAL_Check HAL_ICACHE_GetInt(void);
 | 
				
			||||||
 | 
					uint32_t HAL_ICACHE_GetErrAddr(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_ICACHE_ClearInt(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_Enable(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_Disable(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_Invalidate(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_InvalidateByRange(uint32_t address, uint32_t sizeByte);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_CleanByRange(uint32_t address, uint32_t sizeByte);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_CleanInvalidateByRange(uint32_t address, uint32_t sizeByte);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_CleanInvalidate(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_EnablePMU(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_DisablePMU(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_GetPMU(struct CACHE_PMU_CNT *stat);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_EnableInt(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_DisableInt(void);
 | 
				
			||||||
 | 
					HAL_Check HAL_DCACHE_GetInt(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_DCACHE_ClearInt(void);
 | 
				
			||||||
 | 
					uint32_t HAL_DCACHE_GetErrAddr(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,474 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup CRU
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef _HAL_CRU_H_
 | 
				
			||||||
 | 
					#define _HAL_CRU_H_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*************************** MACRO Definition ****************************/
 | 
				
			||||||
 | 
					/** @defgroup CRU_Exported_Definition_Group1 Basic Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAL_CRU_DBG_ON
 | 
				
			||||||
 | 
					#define HAL_CRU_DBG(fmt, arg...) HAL_SYSLOG("[HAL CRU] " fmt, ##arg)
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_CRU_DBG(fmt, arg...) do { if (0) HAL_SYSLOG("[HAL CRU] " fmt, ##arg); } while (0)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MHZ 1000000
 | 
				
			||||||
 | 
					#define KHZ 1000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef PLL_INPUT_OSC_RATE
 | 
				
			||||||
 | 
					#define PLL_INPUT_OSC_RATE (24 * MHZ)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GENVAL_D16(x, h, l)     ((uint32_t)(((x) & HAL_GENMASK(h, l)) / 16))
 | 
				
			||||||
 | 
					#define GENVAL_D16_REM(x, h, l) ((uint32_t)(((x) & HAL_GENMASK(h, l)) % 16))
 | 
				
			||||||
 | 
					#define WIDTH_TO_MASK(w)        ((1 << (w)) - 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * RESET/GATE fields:
 | 
				
			||||||
 | 
					 *   [31:16]: reserved
 | 
				
			||||||
 | 
					 *   [15:12]: bank
 | 
				
			||||||
 | 
					 *   [11:0]:  id
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CLK_RESET_GET_REG_OFFSET(x) GENVAL_D16(x, 11, 0)
 | 
				
			||||||
 | 
					#define CLK_RESET_GET_BITS_SHIFT(x) GENVAL_D16_REM(x, 11, 0)
 | 
				
			||||||
 | 
					#define CLK_RESET_GET_REG_BANK(x)   HAL_GENVAL(x, 15, 12)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CLK_GATE_GET_REG_OFFSET(x) CLK_RESET_GET_REG_OFFSET(x)
 | 
				
			||||||
 | 
					#define CLK_GATE_GET_BITS_SHIFT(x) CLK_RESET_GET_BITS_SHIFT(x)
 | 
				
			||||||
 | 
					#define CLK_GATE_GET_REG_BANK(x)   CLK_RESET_GET_REG_BANK(x)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * MUX/DIV fields:
 | 
				
			||||||
 | 
					 *   [31:24]: width
 | 
				
			||||||
 | 
					 *   [23:16]: shift
 | 
				
			||||||
 | 
					 *   [15:12]: reserved
 | 
				
			||||||
 | 
					 *   [11:8]:  bank
 | 
				
			||||||
 | 
					 *   [7:0]:   reg
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define CLK_MUX_GET_REG_OFFSET(x) HAL_GENVAL(x, 7,  0)
 | 
				
			||||||
 | 
					#define CLK_MUX_GET_BANK(x)       HAL_GENVAL(x, 11, 8)
 | 
				
			||||||
 | 
					#define CLK_MUX_GET_BITS_SHIFT(x) HAL_GENVAL(x, 23, 16)
 | 
				
			||||||
 | 
					#define CLK_MUX_GET_WIDTH(x)      HAL_GENVAL(x, 31, 24)
 | 
				
			||||||
 | 
					#define CLK_MUX_GET_MASK(x)       (WIDTH_TO_MASK(CLK_MUX_GET_WIDTH(x)) << CLK_MUX_GET_BITS_SHIFT(x))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CLK_DIV_GET_REG_OFFSET(x) CLK_MUX_GET_REG_OFFSET(x)
 | 
				
			||||||
 | 
					#define CLK_DIV_GET_BANK(x)       CLK_MUX_GET_BANK(x)
 | 
				
			||||||
 | 
					#define CLK_DIV_GET_BITS_SHIFT(x) CLK_MUX_GET_BITS_SHIFT(x)
 | 
				
			||||||
 | 
					#define CLK_DIV_GET_WIDTH(x)      CLK_MUX_GET_WIDTH(x)
 | 
				
			||||||
 | 
					#define CLK_DIV_GET_MASK(x)       CLK_MUX_GET_MASK(x)
 | 
				
			||||||
 | 
					#define CLK_DIV_GET_MAXDIV(x)     ((1 << CLK_DIV_GET_WIDTH(x)) - 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * v64 mux = v32 | bank(in bit[35:32])
 | 
				
			||||||
 | 
					 * v64 div = v32 | bank(in bit[39:36])
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#ifdef CRU_CLK_USE_CON_BANK
 | 
				
			||||||
 | 
					#define CLK_GET_MUX(v64) ((uint32_t)(((v64) & 0xFFFFFFFF00000000) >> 32))
 | 
				
			||||||
 | 
					#define CLK_GET_DIV(v64) ((uint32_t)((v64) & 0x00000000FFFFFFFF))
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define CLK_GET_MUX(v32) ((uint32_t)((v32) & 0x0F0F00FFU))
 | 
				
			||||||
 | 
					#define CLK_GET_DIV(v32) ((uint32_t)((((v32) & 0x0000FF00U) >> 8) | \
 | 
				
			||||||
 | 
					                                     (((v32) & 0xF0F00000U) >> 4)))
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define RK_PLL_RATE(_rate, _refdiv, _fbdiv, _postdiv1, _postdiv2, _dsmpd, \
 | 
				
			||||||
 | 
					                    _frac)                                                \
 | 
				
			||||||
 | 
					    {                                                                     \
 | 
				
			||||||
 | 
					        .rate = _rate##U, .fbDiv = _fbdiv, .postDiv1 = _postdiv1,         \
 | 
				
			||||||
 | 
					        .refDiv = _refdiv, .postDiv2 = _postdiv2, .dsmpd = _dsmpd,        \
 | 
				
			||||||
 | 
					        .frac = _frac,                                                    \
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define RK3588_PLL_RATE(_rate, _p, _m, _s, _k) \
 | 
				
			||||||
 | 
					    {                                          \
 | 
				
			||||||
 | 
					        .rate = _rate##U, .p = _p, .m = _m,    \
 | 
				
			||||||
 | 
					        .s = _s, .k = _k,                      \
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CRU_BANK_CFG_FLAGS(reg, sel, gate, soft) \
 | 
				
			||||||
 | 
					    {                                            \
 | 
				
			||||||
 | 
					        .cruBase = reg,                          \
 | 
				
			||||||
 | 
					        .selOffset = sel,                        \
 | 
				
			||||||
 | 
					        .gateOffset = gate,                      \
 | 
				
			||||||
 | 
					        .softOffset = soft,                      \
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct PLL_CONFIG {
 | 
				
			||||||
 | 
					    uint32_t rate;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    union {
 | 
				
			||||||
 | 
					        struct {
 | 
				
			||||||
 | 
					            uint32_t fbDiv;
 | 
				
			||||||
 | 
					            uint32_t postDiv1;
 | 
				
			||||||
 | 
					            uint32_t refDiv;
 | 
				
			||||||
 | 
					            uint32_t postDiv2;
 | 
				
			||||||
 | 
					            uint32_t dsmpd;
 | 
				
			||||||
 | 
					            uint32_t frac;
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					        struct {
 | 
				
			||||||
 | 
					            uint32_t m;
 | 
				
			||||||
 | 
					            uint32_t p;
 | 
				
			||||||
 | 
					            uint32_t s;
 | 
				
			||||||
 | 
					            uint32_t k;
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct PLL_SETUP {
 | 
				
			||||||
 | 
					    __IO uint32_t *conOffset0;
 | 
				
			||||||
 | 
					    __IO uint32_t *conOffset1;
 | 
				
			||||||
 | 
					    __IO uint32_t *conOffset2;
 | 
				
			||||||
 | 
					    __IO uint32_t *conOffset3;
 | 
				
			||||||
 | 
					    __IO uint32_t *conOffset6;
 | 
				
			||||||
 | 
					    __IO uint32_t *modeOffset;
 | 
				
			||||||
 | 
					    __I uint32_t *stat0;
 | 
				
			||||||
 | 
					    uint32_t modeShift;
 | 
				
			||||||
 | 
					    uint32_t lockShift;
 | 
				
			||||||
 | 
					    uint32_t modeMask;
 | 
				
			||||||
 | 
					    const struct PLL_CONFIG *rateTable;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GLB_SRST_FST = 0xfdb9,
 | 
				
			||||||
 | 
					    GLB_SRST_SND = 0xeca8,
 | 
				
			||||||
 | 
					} eCRU_GlbSrstType;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GLB_RST_FST_WDT0 = 0U,
 | 
				
			||||||
 | 
					    GLB_RST_SND_WDT0,
 | 
				
			||||||
 | 
					    GLB_RST_FST_WDT1,
 | 
				
			||||||
 | 
					    GLB_RST_SND_WDT1,
 | 
				
			||||||
 | 
					    GLB_RST_FST_WDT2,
 | 
				
			||||||
 | 
					    GLB_RST_SND_WDT2,
 | 
				
			||||||
 | 
					} eCRU_WdtRstType;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct CRU_BANK_INFO {
 | 
				
			||||||
 | 
					    uint32_t cruBase;
 | 
				
			||||||
 | 
					    uint32_t selOffset;
 | 
				
			||||||
 | 
					    uint32_t gateOffset;
 | 
				
			||||||
 | 
					    uint32_t softOffset;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct HAL_CRU_DEV {
 | 
				
			||||||
 | 
					    const struct CRU_BANK_INFO *banks;
 | 
				
			||||||
 | 
					    uint8_t banksNum;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					extern const struct HAL_CRU_DEV g_cruDev;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					/** @defgroup CRU_Private_Function_Declare Private Function Declare
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define _MHZ(n) ((n) * 1000000)
 | 
				
			||||||
 | 
					#define DIV_NO_REM(pFreq, freq, maxDiv) \
 | 
				
			||||||
 | 
					    ((!((pFreq) % (freq))) && ((pFreq) / (freq) <= (maxDiv)))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int HAL_CRU_FreqGetMux4(uint32_t freq, uint32_t freq0, uint32_t freq1,
 | 
				
			||||||
 | 
					                        uint32_t freq2, uint32_t freq3);
 | 
				
			||||||
 | 
					int HAL_CRU_FreqGetMux3(uint32_t freq, uint32_t freq0, uint32_t freq1,
 | 
				
			||||||
 | 
					                        uint32_t freq2);
 | 
				
			||||||
 | 
					int HAL_CRU_FreqGetMux2(uint32_t freq, uint32_t freq0, uint32_t freq1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					uint32_t HAL_CRU_MuxGetFreq4(uint32_t muxName, uint32_t freq0, uint32_t freq1,
 | 
				
			||||||
 | 
					                             uint32_t freq2, uint32_t freq3);
 | 
				
			||||||
 | 
					uint32_t HAL_CRU_MuxGetFreq3(uint32_t muxName, uint32_t freq0, uint32_t freq1,
 | 
				
			||||||
 | 
					                             uint32_t freq2);
 | 
				
			||||||
 | 
					uint32_t HAL_CRU_MuxGetFreq2(uint32_t muxName, uint32_t freq0, uint32_t freq1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int HAL_CRU_RoundFreqGetMux4(uint32_t freq, uint32_t pFreq0, uint32_t pFreq1,
 | 
				
			||||||
 | 
					                             uint32_t pFreq2, uint32_t pFreq3, uint32_t *pFreqOut);
 | 
				
			||||||
 | 
					int HAL_CRU_RoundFreqGetMux3(uint32_t freq, uint32_t pFreq0, uint32_t pFreq1,
 | 
				
			||||||
 | 
					                             uint32_t pFreq2, uint32_t *pFreqOut);
 | 
				
			||||||
 | 
					int HAL_CRU_RoundFreqGetMux2(uint32_t freq, uint32_t pFreq0, uint32_t pFreq1,
 | 
				
			||||||
 | 
					                             uint32_t *pFreqOut);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup CRU_Public_Function_Declare Public Function Declare
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Get pll freq.
 | 
				
			||||||
 | 
					 * @param  pSetup: Contains PLL register parameters
 | 
				
			||||||
 | 
					 * @return pll rate.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					uint32_t HAL_CRU_GetPllFreq(struct PLL_SETUP *pSetup);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Set pll freq.
 | 
				
			||||||
 | 
					 * @param  pSetup: Contains PLL register parameters
 | 
				
			||||||
 | 
					 * @param  rate: pll set
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_SetPllFreq(struct PLL_SETUP *pSetup, uint32_t rate);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Set pll power up.
 | 
				
			||||||
 | 
					 * @param  pSetup: Contains PLL register parameters
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_SetPllPowerUp(struct PLL_SETUP *pSetup);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Set pll power down.
 | 
				
			||||||
 | 
					 * @param  pSetup: Contains PLL register parameters
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_SetPllPowerDown(struct PLL_SETUP *pSetup);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Check if clk is enabled
 | 
				
			||||||
 | 
					 * @param  clk: clock to check
 | 
				
			||||||
 | 
					 * @return HAL_Check.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Check HAL_CRU_ClkIsEnabled(uint32_t clk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Enable clk
 | 
				
			||||||
 | 
					 * @param  clk: clock to set
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkEnable(uint32_t clk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Disable unused clk
 | 
				
			||||||
 | 
					 * @param  bank: cru bank id
 | 
				
			||||||
 | 
					 * @param  index: gate con offset
 | 
				
			||||||
 | 
					 * @param  val: gate value
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkDisableUnused(uint32_t bank, uint32_t index, uint32_t val);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Disable clk
 | 
				
			||||||
 | 
					 * @param  clk: clock to set
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkDisable(uint32_t clk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Check if clk is reset
 | 
				
			||||||
 | 
					 * @param  clk: clock to check
 | 
				
			||||||
 | 
					 * @return HAL_Check.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Check HAL_CRU_ClkIsReset(uint32_t clk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Assert the reset to the clk
 | 
				
			||||||
 | 
					 * @param  clk: clock to assert
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkResetAssert(uint32_t clk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Deassert the reset to the clk
 | 
				
			||||||
 | 
					 * @param  clk: clock to deassert
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkResetDeassert(uint32_t clk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Sync Assert the resets to the clk
 | 
				
			||||||
 | 
					 * @param  numClks: num clocks to assert
 | 
				
			||||||
 | 
					 * @param  clks: clocks to assert
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkResetSyncAssert(int numClks, uint32_t *clks);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Sync Deassert the resets to the clk
 | 
				
			||||||
 | 
					 * @param  numClks: num clocks to assert
 | 
				
			||||||
 | 
					 * @param  clks: clocks to deassert
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkResetSyncDeassert(int numClks, uint32_t *clks);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set frac div
 | 
				
			||||||
 | 
					 * @param  fracDivName: frac div id(Contains div offset, shift, mask information)
 | 
				
			||||||
 | 
					 * @param  numerator: the numerator to set.
 | 
				
			||||||
 | 
					 * @param  denominator: the denominator to set.
 | 
				
			||||||
 | 
					 * @return HAL_Status
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkSetFracDiv(uint32_t fracDivName,
 | 
				
			||||||
 | 
					                                 uint32_t numerator,
 | 
				
			||||||
 | 
					                                 uint32_t denominator);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get frac div
 | 
				
			||||||
 | 
					 * @param  fracDivName: frac div id(Contains div offset, shift, mask information)
 | 
				
			||||||
 | 
					 * @param  numerator: the returned numerator.
 | 
				
			||||||
 | 
					 * @param  denominator: the returned denominator.
 | 
				
			||||||
 | 
					 * @return HAL_Status
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkGetFracDiv(uint32_t fracDivName,
 | 
				
			||||||
 | 
					                                 uint32_t *numerator,
 | 
				
			||||||
 | 
					                                 uint32_t *denominator);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set integer div
 | 
				
			||||||
 | 
					 * @param  divName: div id(Contains div offset, shift, mask information)
 | 
				
			||||||
 | 
					 * @param  divValue: div value
 | 
				
			||||||
 | 
					 * @return NONE
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkSetDiv(uint32_t divName, uint32_t divValue);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get integer div
 | 
				
			||||||
 | 
					 * @param  divName: div id (Contains div offset, shift, mask information)
 | 
				
			||||||
 | 
					 * @return div value
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					uint32_t HAL_CRU_ClkGetDiv(uint32_t divName);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Set mux
 | 
				
			||||||
 | 
					 * @param  muxName: mux id (Contains mux offset, shift, mask information)
 | 
				
			||||||
 | 
					 * @param  muxValue: mux value
 | 
				
			||||||
 | 
					 * @return NONE
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkSetMux(uint32_t muxName, uint32_t muxValue);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get mux
 | 
				
			||||||
 | 
					 * @param  muxName: mux id (Contains mux offset, shift, mask information)
 | 
				
			||||||
 | 
					 * @return mux value
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					uint32_t HAL_CRU_ClkGetMux(uint32_t muxName);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get frac div config.
 | 
				
			||||||
 | 
					 * @param  rateOut: clk out rate.
 | 
				
			||||||
 | 
					 * @param  rate: clk src rate.
 | 
				
			||||||
 | 
					 * @param  numerator: the returned numerator.
 | 
				
			||||||
 | 
					 * @param  denominator: the returned denominator.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_FracdivGetConfig(uint32_t rateOut, uint32_t rate,
 | 
				
			||||||
 | 
					                                    uint32_t *numerator,
 | 
				
			||||||
 | 
					                                    uint32_t *denominator);
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Get clk freq.
 | 
				
			||||||
 | 
					 * @param  clockName: CLOCK_Name id.
 | 
				
			||||||
 | 
					 * @return rate.
 | 
				
			||||||
 | 
					 * @attention these APIs allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					uint32_t HAL_CRU_ClkGetFreq(eCLOCK_Name clockName);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief Set clk freq.
 | 
				
			||||||
 | 
					 * @param  clockName: CLOCK_Name id.
 | 
				
			||||||
 | 
					 * @param  rate: clk rate.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 * @attention these APIs allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkSetFreq(eCLOCK_Name clockName, uint32_t rate);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief vop dclk enable.
 | 
				
			||||||
 | 
					 * @param  gateId: gate id
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 * @attention these APIs allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_VopDclkEnable(uint32_t gateId);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief vop dclk disable.
 | 
				
			||||||
 | 
					 * @param  gateId: gate id
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 * @attention these APIs allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_VopDclkDisable(uint32_t gateId);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  Get Np5 best div.
 | 
				
			||||||
 | 
					 * @param  clockName: clk id.
 | 
				
			||||||
 | 
					 * @param  rate: clk rate.
 | 
				
			||||||
 | 
					 * @param  pRate: clk parent rate
 | 
				
			||||||
 | 
					 * @param  bestdiv: the returned bestdiv.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_ClkNp5BestDiv(eCLOCK_Name clockName, uint32_t rate, uint32_t pRate, uint32_t *bestdiv);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  assert CRU global software reset.
 | 
				
			||||||
 | 
					 * @param  type: global software reset type.
 | 
				
			||||||
 | 
					 * @return HAL_INVAL if the SoC does not support.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_SetGlbSrst(eCRU_GlbSrstType type);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief wdt glbrst enable.
 | 
				
			||||||
 | 
					 * @param  wdtType: wdt reset type.
 | 
				
			||||||
 | 
					 * @return HAL_OK.
 | 
				
			||||||
 | 
					 * @attention these APIs allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_WdtGlbRstEnable(eCRU_WdtRstType wdtType);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief pll output freq Compensation.
 | 
				
			||||||
 | 
					 * @param  clockName: CLOCK_Name id.
 | 
				
			||||||
 | 
					 * @param  ppm: Efforts to compensate.
 | 
				
			||||||
 | 
					 * @return HAL_OK.
 | 
				
			||||||
 | 
					 * @attention these APIs allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_PllCompensation(eCLOCK_Name clockName, int ppm);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief CRU suspend.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 * @attention these APIs allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_Suspend(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief CRU resume.
 | 
				
			||||||
 | 
					 * @return HAL_Status.
 | 
				
			||||||
 | 
					 * @attention these APIs allow direct use in the HAL layer.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_CRU_Resume(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAL_CRU_AS_FEATURE_ENABLED
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  it is for AS init.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_CRU_AsInit(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  it is for AS enable.
 | 
				
			||||||
 | 
					 * @param  ch: channel
 | 
				
			||||||
 | 
					 * @param  en: 1 is enable, 0 is disable.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void HAL_CRU_AsEnable(uint8_t ch, uint8_t en);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,85 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2018-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef _HAL_DEBUG_H_
 | 
				
			||||||
 | 
					#define _HAL_DEBUG_H_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					#include "libserial.h"
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup DEBUG
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Run only for debugging, please refer to how-to-use for the definition of the specification. */
 | 
				
			||||||
 | 
					//#define HAL_DBG_USING_RTT_SERIAL
 | 
				
			||||||
 | 
					//#define HAL_DBG_USING_LIBC_PRINTF
 | 
				
			||||||
 | 
					//#define HAL_DBG_USING_HAL_PRINTF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_SYSLOG printf
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup DEBUG_Exported_Definition_Group1 Basic Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef HAL_SYSLOG
 | 
				
			||||||
 | 
					#define HAL_SYSLOG HAL_DBG_Printf
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HAL_DBG_ON) && defined(HAL_DBG_INFO_ON)
 | 
				
			||||||
 | 
					#define HAL_DBG(fmt, arg...) HAL_SYSLOG("[HAL INFO] " fmt, ##arg)
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_DBG(fmt, arg...) do { if (0) HAL_SYSLOG("[HAL INFO] " fmt, ##arg); } while (0)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HAL_DBG_ON) && defined(HAL_DBG_WRN_ON)
 | 
				
			||||||
 | 
					#define HAL_DBG_WRN(fmt, arg...) HAL_SYSLOG("[HAL WARNING] " fmt, ##arg)
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_DBG_WRN(fmt, arg...) do { if (0) HAL_SYSLOG("[HAL WARNING] " fmt, ##arg); } while (0)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HAL_DBG_ON) && defined(HAL_DBG_ERR_ON)
 | 
				
			||||||
 | 
					#define HAL_DBG_ERR(fmt, arg...) HAL_SYSLOG("[HAL ERROR] " fmt, ##arg)
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_DBG_ERR(fmt, arg...) do { if (0) HAL_SYSLOG("[HAL ERROR] " fmt, ##arg); } while (0)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HAL_DBG_ON) && defined(HAL_ASSERT_ON)
 | 
				
			||||||
 | 
					#define HAL_ASSERT(expr)                                        \
 | 
				
			||||||
 | 
					    do {                                                        \
 | 
				
			||||||
 | 
					        if (!(expr))                                            \
 | 
				
			||||||
 | 
					            HAL_AssertFailed((const char *)__FILE__, __LINE__); \
 | 
				
			||||||
 | 
					    } while (0)
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_ASSERT(expr)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					/** @defgroup DEBUG_Public_Function_Declare Public Function Declare
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void HAL_AssertFailed(const char *file, uint32_t line);
 | 
				
			||||||
 | 
					HAL_Status HAL_DBG_HEX(char *s, void *buf, uint32_t width, uint32_t len);
 | 
				
			||||||
 | 
					#ifdef __GNUC__
 | 
				
			||||||
 | 
					__attribute__((__format__(printf, 1, 2)))
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					int32_t HAL_DBG_Printf(const char *format, ...);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,205 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup HAL_DEF
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef _HAL_DEF_H_
 | 
				
			||||||
 | 
					#define _HAL_DEF_H_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// #include <stdio.h>
 | 
				
			||||||
 | 
					#include <stdlib.h>
 | 
				
			||||||
 | 
					#include <string.h>
 | 
				
			||||||
 | 
					#include <stdarg.h>
 | 
				
			||||||
 | 
					#include <stdint.h>
 | 
				
			||||||
 | 
					#include <stdbool.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "soc.h"
 | 
				
			||||||
 | 
					#include "hal_list.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					/** @defgroup HAL_DEF_Exported_Definition_Group1 Basic Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SET_BIT(REG, BIT)    ((*(volatile uint32_t *)&(REG)) |= (BIT))        /**< Set 1 to the register specific bit field */
 | 
				
			||||||
 | 
					#define CLEAR_BIT(REG, MASK) ((*(volatile uint32_t *)&(REG)) &= ~(MASK))      /**< Clear the specific bits filed from the register */
 | 
				
			||||||
 | 
					#define READ_BIT(REG, MASK)  ((*(volatile const uint32_t *)&(REG)) & (MASK))  /**< Read the value of a specific bits field from the register */
 | 
				
			||||||
 | 
					#define CLEAR_REG(REG)       ((*(volatile uint32_t *)&(REG)) = (0x0))         /**< Write 0 to the register */
 | 
				
			||||||
 | 
					#define WRITE_REG(REG, VAL)  ((*(volatile uint32_t *)&(REG)) = (VAL))         /**< Write the register */
 | 
				
			||||||
 | 
					#define READ_REG(REG)        ((*(volatile const uint32_t *)&(REG)))           /**< Read the register */
 | 
				
			||||||
 | 
					#define MODIFY_REG(REG, CLEARMASK, SETMASK) \
 | 
				
			||||||
 | 
					        WRITE_REG((REG), (((READ_REG(REG)) & (~(CLEARMASK))) | (SETMASK)))    /**< Clear and set the value of a specific bits field from the register */
 | 
				
			||||||
 | 
					#define POSITION_VAL(VAL) (__CLZ(__RBIT(VAL)))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(__GNUC__) || defined(__CC_ARM)
 | 
				
			||||||
 | 
					#define MASK_TO_WE(msk) (__builtin_constant_p(msk) ? ((msk) > 0xFFFFU ? 0 : ((msk) << 16)) : ((msk) << 16))
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define MASK_TO_WE(msk) ((msk) << 16)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#define VAL_MASK_WE(msk, val)            ((MASK_TO_WE(msk)) | (val))
 | 
				
			||||||
 | 
					#define WRITE_REG_MASK_WE(reg, msk, val) WRITE_REG(reg, (VAL_MASK_WE(msk, val)))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Misc OPS Marco */
 | 
				
			||||||
 | 
					#define HAL_MAX_DELAY 0xFFFFFFFFU
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define RESET                     0
 | 
				
			||||||
 | 
					#define HAL_IS_BIT_SET(REG, MASK) (((*(volatile uint32_t *)&(REG)) & (MASK)) != RESET)  /**< Check if the the specific bits filed from the register is valid */
 | 
				
			||||||
 | 
					#define HAL_IS_BIT_CLR(REG, MASK) (((*(volatile uint32_t *)&(REG)) & (MASK)) == RESET)  /**< Check if the the specific bits filed from the register is isvalid */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_BIT(nr)       (1UL << (nr))
 | 
				
			||||||
 | 
					#define HAL_ARRAY_SIZE(a) (sizeof((a)) / sizeof((a)[0]))
 | 
				
			||||||
 | 
					#define HAL_MAX(x, y)     ((x) > (y) ? (x) : (y))
 | 
				
			||||||
 | 
					#define HAL_MIN(x, y)     ((x) < (y) ? (x) : (y))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_DIV_ROUND_UP(x, y) (((x) + (y) - 1) / (y))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_IS_ALIGNED(x, a) (((x) & (a - 1)) == 0)
 | 
				
			||||||
 | 
					#ifdef CACHE_LINE_SIZE
 | 
				
			||||||
 | 
					#define HAL_IS_CACHELINE_ALIGNED(x) HAL_IS_ALIGNED((uint32_t)(x), CACHE_LINE_SIZE)
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_IS_CACHELINE_ALIGNED(x) HAL_IS_ALIGNED((uint32_t)(x), 4)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* Compiller Macro */
 | 
				
			||||||
 | 
					#if defined(__GNUC__) || defined(__clang__) || defined(__CC_ARM) || defined(__ICCARM__)
 | 
				
			||||||
 | 
					#define HAL_UNUSED __attribute__((__unused__))
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_UNUSED
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef CACHE_LINE_SIZE
 | 
				
			||||||
 | 
					#define HAL_CACHELINE_ALIGNED __ALIGNED(CACHE_LINE_SIZE)
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_CACHELINE_ALIGNED
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAL_SRAM_SECTION_ENABLED
 | 
				
			||||||
 | 
					#define HAL_SECTION_SRAM_CODE   __attribute__((section(".sram_code")))
 | 
				
			||||||
 | 
					#define HAL_SECTION_SRAM_RODATA __attribute__((section(".sram_rodata")))
 | 
				
			||||||
 | 
					#define HAL_SECTION_SRAM_DATA   __attribute__((section(".sram_data")))
 | 
				
			||||||
 | 
					#define HAL_SECTION_SRAM_BSS    __attribute__((section(".sram_bss")))
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_SECTION_SRAM_CODE
 | 
				
			||||||
 | 
					#define HAL_SECTION_SRAM_RODATA
 | 
				
			||||||
 | 
					#define HAL_SECTION_SRAM_DATA
 | 
				
			||||||
 | 
					#define HAL_SECTION_SRAM_BSS
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAL_PSRAM_SECTION_ENABLED
 | 
				
			||||||
 | 
					#define HAL_SECTION_PSRAM_CODE   __attribute__((section(".psram_code")))
 | 
				
			||||||
 | 
					#define HAL_SECTION_PSRAM_RODATA __attribute__((section(".psram_rodata")))
 | 
				
			||||||
 | 
					#define HAL_SECTION_PSRAM_DATA   __attribute__((section(".psram_data")))
 | 
				
			||||||
 | 
					#define HAL_SECTION_PSRAM_BSS    __attribute__((section(".psram_bss")))
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_SECTION_PSRAM_CODE
 | 
				
			||||||
 | 
					#define HAL_SECTION_PSRAM_RODATA
 | 
				
			||||||
 | 
					#define HAL_SECTION_PSRAM_DATA
 | 
				
			||||||
 | 
					#define HAL_SECTION_PSRAM_BSS
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAL_XIP_SECTION_ENABLED
 | 
				
			||||||
 | 
					#define HAL_SECTION_XIP_CODE   __attribute__((section(".xip_code")))
 | 
				
			||||||
 | 
					#define HAL_SECTION_XIP_RODATA __attribute__((section(".xip_rodata")))
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define HAL_SECTION_XIP_CODE
 | 
				
			||||||
 | 
					#define HAL_SECTION_XIP_RODATA
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_GENMASK(h, l)       (((~0U) << (l)) & (~0U >> (32 - 1 - (h))))
 | 
				
			||||||
 | 
					#define HAL_GENVAL(x, h, l)     ((uint32_t)(((x) & HAL_GENMASK(h, l)) >> (l)))
 | 
				
			||||||
 | 
					#define HAL_GENMASK_ULL(h, l)   (((~0ULL) << (l)) & (~0ULL >> (64 - 1 - (h))))
 | 
				
			||||||
 | 
					#define HAL_GENVAL_ULL(x, h, l) ((uint64_t)(((x) & HAL_GENMASK_ULL(h, l)) >> (l)))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** MCU systick clock source */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    HAL_SYSTICK_CLKSRC_CORE,
 | 
				
			||||||
 | 
					    HAL_SYSTICK_CLKSRC_EXT
 | 
				
			||||||
 | 
					} eHAL_systickClkSource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** Check if is MCU systick clock source */
 | 
				
			||||||
 | 
					#define IS_SYSTICK_SOURCE(s) (((s) == HAL_SYSTICK_CLKSRC_CORE) || ((s) == HAL_SYSTICK_CLKSRC_EXT))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					/** HAL boolean type definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    HAL_FALSE = 0x00U,
 | 
				
			||||||
 | 
					    HAL_TRUE  = 0x01U
 | 
				
			||||||
 | 
					} HAL_Check;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** HAL error code definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    HAL_OK      = 0x00U,
 | 
				
			||||||
 | 
					    HAL_ERROR   = (-1),
 | 
				
			||||||
 | 
					    HAL_BUSY    = (-16),
 | 
				
			||||||
 | 
					    HAL_NODEV   = (-19),
 | 
				
			||||||
 | 
					    HAL_INVAL   = (-22),
 | 
				
			||||||
 | 
					    HAL_NOSYS   = (-38),
 | 
				
			||||||
 | 
					    HAL_TIMEOUT = (-110)
 | 
				
			||||||
 | 
					} HAL_Status;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** HAL functional status definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    HAL_DISABLE = 0x00U,
 | 
				
			||||||
 | 
					    HAL_ENABLE  = 0x01U
 | 
				
			||||||
 | 
					} HAL_FuncStatus;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** HAL lock structures definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    HAL_UNLOCKED = 0x00U,
 | 
				
			||||||
 | 
					    HAL_LOCKED   = 0x01U
 | 
				
			||||||
 | 
					} HAL_LockStatus;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** RK GPIO bank definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					#ifdef GPIO0
 | 
				
			||||||
 | 
					    GPIO_BANK0 = 0,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO1
 | 
				
			||||||
 | 
					    GPIO_BANK1 = 1,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO2
 | 
				
			||||||
 | 
					    GPIO_BANK2 = 2,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO3
 | 
				
			||||||
 | 
					    GPIO_BANK3 = 3,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO4
 | 
				
			||||||
 | 
					    GPIO_BANK4 = 4,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO0_EXP
 | 
				
			||||||
 | 
					    GPIO_BANK0_EXP = 5,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO1_EXP
 | 
				
			||||||
 | 
					    GPIO_BANK1_EXP = 6,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO2_EXP
 | 
				
			||||||
 | 
					    GPIO_BANK2_EXP = 7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO3_EXP
 | 
				
			||||||
 | 
					    GPIO_BANK3_EXP = 8,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#ifdef GPIO4_EXP
 | 
				
			||||||
 | 
					    GPIO_BANK4_EXP = 9,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					    GPIO_BANK_NUM
 | 
				
			||||||
 | 
					} eGPIO_bankId;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** HAL function type definition */
 | 
				
			||||||
 | 
					typedef void (*pFunc)(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,425 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					  * @{
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup GMAC
 | 
				
			||||||
 | 
					  * @{
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __HAL_GMAC_H
 | 
				
			||||||
 | 
					#define __HAL_GMAC_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					#include "hal_base.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					/** @defgroup GMAC_Exported_Definition_Group1 Basic Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* GMAC PHY indicates what features are supported by the interface. */
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_10baseT_Half      (1 << 0)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_10baseT_Full      (1 << 1)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_100baseT_Half     (1 << 2)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_100baseT_Full     (1 << 3)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_1000baseT_Half    (1 << 4)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_1000baseT_Full    (1 << 5)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_Autoneg           (1 << 6)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_TP                (1 << 7)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_AUI               (1 << 8)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_MII               (1 << 9)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_FIBRE             (1 << 10)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_BNC               (1 << 11)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_10000baseT_Full   (1 << 12)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_Pause             (1 << 13)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_Asym_Pause        (1 << 14)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_2500baseX_Full    (1 << 15)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_Backplane         (1 << 16)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_1000baseKX_Full   (1 << 17)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_10000baseKX4_Full (1 << 18)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_10000baseKR_Full  (1 << 19)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_10000baseR_FEC    (1 << 20)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_1000baseX_Half    (1 << 21)
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_SUPPORTED_1000baseX_Full    (1 << 22)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_DEFAULT_FEATURES (HAL_GMAC_PHY_SUPPORTED_Autoneg | \
 | 
				
			||||||
 | 
					                                       HAL_GMAC_PHY_SUPPORTED_TP |      \
 | 
				
			||||||
 | 
					                                       HAL_GMAC_PHY_SUPPORTED_MII)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_10BT_FEATURES (HAL_GMAC_PHY_SUPPORTED_10baseT_Half | \
 | 
				
			||||||
 | 
					                                    HAL_GMAC_PHY_SUPPORTED_10baseT_Full)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_100BT_FEATURES (HAL_GMAC_PHY_SUPPORTED_100baseT_Half | \
 | 
				
			||||||
 | 
					                                     HAL_GMAC_PHY_SUPPORTED_100baseT_Full)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_1000BT_FEATURES (HAL_GMAC_PHY_SUPPORTED_1000baseT_Half | \
 | 
				
			||||||
 | 
					                                      HAL_GMAC_PHY_SUPPORTED_1000baseT_Full)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_BASIC_FEATURES (HAL_GMAC_PHY_10BT_FEATURES |  \
 | 
				
			||||||
 | 
					                                     HAL_GMAC_PHY_100BT_FEATURES | \
 | 
				
			||||||
 | 
					                                     HAL_GMAC_PHY_DEFAULT_FEATURES)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_GMAC_PHY_GBIT_FEATURES (HAL_GMAC_PHY_BASIC_FEATURES | \
 | 
				
			||||||
 | 
					                                    HAL_GMAC_PHY_1000BT_FEATURES)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* GMAC flow ctrl Definition */
 | 
				
			||||||
 | 
					#define HAL_GMAC_FLOW_OFF  0
 | 
				
			||||||
 | 
					#define HAL_GMAC_FLOW_RX   1
 | 
				
			||||||
 | 
					#define HAL_GMAC_FLOW_TX   2
 | 
				
			||||||
 | 
					#define HAL_GMAC_FLOW_AUTO (HAL_GMAC_FLOW_TX | HAL_GMAC_FLOW_RX)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* GMAC descriptions and buffers Definition */
 | 
				
			||||||
 | 
					#define HAL_GMAC_ALIGN(x, a)      (((x) + (a) - 1) & ~((a) - 1))
 | 
				
			||||||
 | 
					#define HAL_GMAC_DESCRIPTOR_WORDS 4
 | 
				
			||||||
 | 
					#define HAL_GMAC_DESCRIPTOR_SIZE  (HAL_GMAC_DESCRIPTOR_WORDS * 4)
 | 
				
			||||||
 | 
					#define HAL_GMAC_BUFFER_ALIGN     64
 | 
				
			||||||
 | 
					#define HAL_GMAC_MAX_FRAME_SIZE   1518
 | 
				
			||||||
 | 
					#define HAL_GMAC_MAX_PACKET_SIZE  HAL_GMAC_ALIGN(HAL_GMAC_MAX_FRAME_SIZE, HAL_GMAC_BUFFER_ALIGN)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					struct GMAC_HANDLE;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC PHY Speed
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PHY_SPEED_10M   = 10,
 | 
				
			||||||
 | 
					    PHY_SPEED_100M  = 100,
 | 
				
			||||||
 | 
					    PHY_SPEED_1000M = 1000,
 | 
				
			||||||
 | 
					} eGMAC_PHY_SPEED;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  GMAC PHY Duplex
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PHY_DUPLEX_HALF = 0,
 | 
				
			||||||
 | 
					    PHY_DUPLEX_FULL = 1,
 | 
				
			||||||
 | 
					} eGMAC_PHY_DUPLEX;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief  GMAC PHY Auto Negrotetion
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PHY_AUTONEG_DISABLE = 0,
 | 
				
			||||||
 | 
					    PHY_AUTONEG_ENABLE  = 1,
 | 
				
			||||||
 | 
					} eGMAC_PHY_NEGROTETION;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC PHY Interface Mode
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PHY_INTERFACE_MODE_MII,
 | 
				
			||||||
 | 
					    PHY_INTERFACE_MODE_RMII,
 | 
				
			||||||
 | 
					    PHY_INTERFACE_MODE_RGMII,
 | 
				
			||||||
 | 
					    PHY_INTERFACE_MODE_NONE,
 | 
				
			||||||
 | 
					} eGMAC_PHY_Interface;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC DMA IRQ Status
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    DMA_UNKNOWN  = 0x0,
 | 
				
			||||||
 | 
					    DMA_HANLE_RX = 0x1,
 | 
				
			||||||
 | 
					    DMA_HANLE_TX = 0x2,
 | 
				
			||||||
 | 
					    DMA_TX_ERROR = 0x10,
 | 
				
			||||||
 | 
					    DMA_RX_ERROR = 0x20,
 | 
				
			||||||
 | 
					} eGMAC_IRQ_Status;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC PHY OPS Structure Definition
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					struct GMAC_PHY_OPS {
 | 
				
			||||||
 | 
					    HAL_Status (*init)(struct GMAC_HANDLE *pGMAC);     /**< Will be called during HAL_GMAC_PHYInit(). */
 | 
				
			||||||
 | 
					    HAL_Status (*config)(struct GMAC_HANDLE *pGMAC);   /**< Called to configure the PHY, and modify the PHY,
 | 
				
			||||||
 | 
					                                                            based on the results. Should be called after HAL_GMAC_PHYInit(). */
 | 
				
			||||||
 | 
					    HAL_Status (*startup)(struct GMAC_HANDLE *pGMAC);  /**< Called when starting up the PHY */
 | 
				
			||||||
 | 
					    HAL_Status (*shutdown)(struct GMAC_HANDLE *pGMAC); /**< Called when bringing down the PHY */
 | 
				
			||||||
 | 
					    HAL_Status (*reset)(struct GMAC_HANDLE *pGMAC);    /**< Called when hardware reset */
 | 
				
			||||||
 | 
					    HAL_Status (*softreset)(struct GMAC_HANDLE *pGMAC);/**< Called when soft reset */
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC PHY Config Structure Definition
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					struct GMAC_PHY_Config {
 | 
				
			||||||
 | 
					    eGMAC_PHY_Interface interface;/**< Ethernet interface mode. */
 | 
				
			||||||
 | 
					    int16_t phyAddress;           /**< Ethernet PHY address,
 | 
				
			||||||
 | 
					                                       This parameter must be a number between Min = 0 and Max = 31 */
 | 
				
			||||||
 | 
					    eGMAC_PHY_NEGROTETION neg;    /**< Selects or disable the AutoNegotiation mode for the external PHY,
 | 
				
			||||||
 | 
					                                       The AutoNegotiation allows an automatic setting of the Speed
 | 
				
			||||||
 | 
					                                       (10/100/1000 Mbps) and the mode (half/full-duplex). */
 | 
				
			||||||
 | 
					    eGMAC_PHY_SPEED speed;        /**< Sets the Ethernet speed: 10/100/1000 Mbps
 | 
				
			||||||
 | 
					                                       while disable AutoNegotiation. */
 | 
				
			||||||
 | 
					    eGMAC_PHY_DUPLEX duplexMode;  /**< Selects the Ethernet duplex mode: Half-Duplex or
 | 
				
			||||||
 | 
					                                       Full-Duplex mode while disable AutoNegotiation. */
 | 
				
			||||||
 | 
					    eGMAC_PHY_SPEED maxSpeed;     /**< Sets the Ethernet max speed: 10/100/1000 Mbps. */
 | 
				
			||||||
 | 
					    uint32_t features;            /**< Sets the Ethernet PHY features. */
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC PHY Status Structure Definition
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					struct GMAC_PHY_STATUS {
 | 
				
			||||||
 | 
					    eGMAC_PHY_Interface interface;    /**< Ethernet interface mode. */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* forced speed & duplex (no autoneg)
 | 
				
			||||||
 | 
					     * partner speed & duplex & pause (autoneg)
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    eGMAC_PHY_SPEED speed;            /**< Ethernet speed. */
 | 
				
			||||||
 | 
					    eGMAC_PHY_DUPLEX duplex;          /**< Ethernet duplex. */
 | 
				
			||||||
 | 
					    eGMAC_PHY_SPEED maxSpeed;         /**< Ethernet max speed. */
 | 
				
			||||||
 | 
					    eGMAC_PHY_NEGROTETION neg;        /**< Ethernet AutoNegotiation or not. */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* The most recently read link state */
 | 
				
			||||||
 | 
					    int link;                         /**< Ethernet current link. */
 | 
				
			||||||
 | 
					    int oldLink;                      /**< Store the Ethernet last link. */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    uint32_t features;                /**< Ethernet PHY actual features. */
 | 
				
			||||||
 | 
					    uint32_t advertising;             /**< Ethernet PHY advertising features. */
 | 
				
			||||||
 | 
					    uint32_t supported;               /**< Ethernet PHY supported features. */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    int16_t addr;                     /**< Ethernet PHY address. */
 | 
				
			||||||
 | 
					    int16_t pause;                    /**< Ethernet PHY address. */
 | 
				
			||||||
 | 
					    uint32_t phyID;                   /**< Ethernet PHY ID. */
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC Link Config Structure Definition
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					struct GMAC_Link {
 | 
				
			||||||
 | 
					    uint32_t speedMask;
 | 
				
			||||||
 | 
					    uint32_t speed10;
 | 
				
			||||||
 | 
					    uint32_t speed100;
 | 
				
			||||||
 | 
					    uint32_t speed1000;
 | 
				
			||||||
 | 
					    uint32_t duplex;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC DMA Descriptors Data Structure Definition
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					struct GMAC_Desc {
 | 
				
			||||||
 | 
					    uint32_t des0; /**< DMA Descriptors first word */
 | 
				
			||||||
 | 
					    uint32_t des1; /**< DMA Descriptors second word */
 | 
				
			||||||
 | 
					    uint32_t des2; /**< DMA Descriptors third word */
 | 
				
			||||||
 | 
					    uint32_t des3; /**< DMA Descriptors four word */
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC DMA Transfer Status Structure Definition
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					struct GMAC_DMAStats {
 | 
				
			||||||
 | 
					    uint32_t txUndeflowIRQ;
 | 
				
			||||||
 | 
					    uint32_t txProcessStoppedIRQ;
 | 
				
			||||||
 | 
					    uint32_t txJabberIRQ;
 | 
				
			||||||
 | 
					    uint32_t rxOverflowIRQ;
 | 
				
			||||||
 | 
					    uint32_t rxBufUnavIRQ;
 | 
				
			||||||
 | 
					    uint32_t rxProcessStoppedIRQ;
 | 
				
			||||||
 | 
					    uint32_t rxWatchdogIRQ;
 | 
				
			||||||
 | 
					    uint32_t txEarlyIRQ;
 | 
				
			||||||
 | 
					    uint32_t fatalBusErrorIRQ;
 | 
				
			||||||
 | 
					    uint32_t normalIRQN;
 | 
				
			||||||
 | 
					    uint32_t rxNormalIRQN;
 | 
				
			||||||
 | 
					    uint32_t txNormallIRQN;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    uint32_t rxEarlyIRQ;
 | 
				
			||||||
 | 
					    uint32_t thresHold;
 | 
				
			||||||
 | 
					    uint32_t txPktN;
 | 
				
			||||||
 | 
					    uint32_t rxPktN;
 | 
				
			||||||
 | 
					    uint32_t txBytesN;
 | 
				
			||||||
 | 
					    uint32_t rxBytesN;
 | 
				
			||||||
 | 
					    uint32_t txErrors;
 | 
				
			||||||
 | 
					    uint32_t rxErrors;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC device information Structure Definition
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					struct GMAC_DEVICE_INFO {
 | 
				
			||||||
 | 
					    uint32_t miiAddrShift;
 | 
				
			||||||
 | 
					    uint32_t miiAddrMask;
 | 
				
			||||||
 | 
					    uint32_t miiRegShift;
 | 
				
			||||||
 | 
					    uint32_t miiRegMask;
 | 
				
			||||||
 | 
					    uint32_t clkCsrShift;
 | 
				
			||||||
 | 
					    uint32_t clkCsrMask;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC Handle Structure Definition
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					struct GMAC_HANDLE {
 | 
				
			||||||
 | 
					    struct GMAC_REG *pReg;                /**< Register base address */
 | 
				
			||||||
 | 
					    uint32_t clkCSR;                      /**< clock csr value, div for MDC clock */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    struct GMAC_DEVICE_INFO mac;          /**< MAC information */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    struct GMAC_PHY_OPS phyOps;           /**< phy ops callback function */
 | 
				
			||||||
 | 
					    struct GMAC_PHY_Config phyConfig;     /**< phy config provied by user */
 | 
				
			||||||
 | 
					    struct GMAC_PHY_STATUS phyStatus;     /**< phy status */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    struct GMAC_Link link;                /**< GMAC link config */
 | 
				
			||||||
 | 
					    struct GMAC_DMAStats extraStatus;     /**< GMAC DMA transfer status */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    struct GMAC_Desc *rxDescs;            /**< First Rx descriptor pointer */
 | 
				
			||||||
 | 
					    struct GMAC_Desc *txDescs;            /**< First Tx descriptor pointer */
 | 
				
			||||||
 | 
					    uint8_t *txBuf;                       /**< First Tx buffer pointer */
 | 
				
			||||||
 | 
					    uint8_t *rxBuf;                       /**< First Tx buffer pointer */
 | 
				
			||||||
 | 
					    uint32_t txDescIdx;                   /**< Current Tx descriptor index */
 | 
				
			||||||
 | 
					    uint32_t rxDescIdx;                   /**< Current Rx descriptor pointer */
 | 
				
			||||||
 | 
					    uint32_t txSize;                      /**< Tx descriptor size*/
 | 
				
			||||||
 | 
					    uint32_t rxSize;                      /**< Rx descriptor size */
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define PM_RUNTIME_TYPE_MUTI_SFT (3)
 | 
				
			||||||
 | 
					#define PM_RUNTIME_PER_TYPE_NUM  (8)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define PM_RUNTIME_TYPE_TO_FIRST_ID(type) ((type) << PM_RUNTIME_TYPE_MUTI_SFT)
 | 
				
			||||||
 | 
					#define PM_RUNTIME_ID_TO_TYPE(id)         ((id) >> PM_RUNTIME_TYPE_MUTI_SFT)
 | 
				
			||||||
 | 
					#define PM_RUNTIME_ID_TO_TYPE_OFFSET(id)  ((id) % PM_RUNTIME_PER_TYPE_NUM)
 | 
				
			||||||
 | 
					#define PM_RUNTIME_ID_TYPE_BIT_MSK(id)    HAL_BIT(((id) % PM_RUNTIME_PER_TYPE_NUM))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define PM_DISPLAY_REQUESTED(pdata) ((pdata)->bits[PM_RUNTIME_TYPE_DISPLAY])
 | 
				
			||||||
 | 
					#define PM_UART_REQUESTED(pdata)    ((pdata)->bits[PM_RUNTIME_TYPE_UART])
 | 
				
			||||||
 | 
					#define PM_I2C_REQUESTED(pdata)     ((pdata)->bits[PM_RUNTIME_TYPE_I2C])
 | 
				
			||||||
 | 
					#define PM_INTF_REQUESTED(pdata)    ((pdata)->bits[PM_RUNTIME_TYPE_INTF])
 | 
				
			||||||
 | 
					#define PM_HS_INTF_REQUESTED(pdata) ((pdata)->bits[PM_RUNTIME_TYPE_HS_INTF])
 | 
				
			||||||
 | 
					#define PM_SPI_REQUESTED(pdata)     ((pdata)->bits[PM_RUNTIME_TYPE_SPI])
 | 
				
			||||||
 | 
					#define PM_CIF_REQUESTED(pdata)     ((pdata)->bits[PM_RUNTIME_TYPE_CIF])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* suspend config id */
 | 
				
			||||||
 | 
					#define PM_SLEEP_MODE_CONFIG   0x01
 | 
				
			||||||
 | 
					#define PM_SLEEP_WAKEUP_SOURCE 0x02
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					enum {
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_INTF = 0, /**< normal interface */
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_DISPLAY,
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_AUDIO,
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_HS_INTF, /**< high speed interface */
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_STORAGE,
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_UART,
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_I2C,
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_SPI,
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_CIF,
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_DEVICE,
 | 
				
			||||||
 | 
					    PM_RUNTIME_TYPE_END,
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PM_RUNTIME_IDLE_ONLY = 0,
 | 
				
			||||||
 | 
					    PM_RUNTIME_IDLE_NORMAL,
 | 
				
			||||||
 | 
					    PM_RUNTIME_IDLE_DEEP,
 | 
				
			||||||
 | 
					    PM_RUNTIME_IDLE_DEEP1,
 | 
				
			||||||
 | 
					    PM_RUNTIME_IDLE_DEEP2,
 | 
				
			||||||
 | 
					} ePM_RUNTIME_idleMode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_INTF_INVLD = PM_RUNTIME_TYPE_TO_FIRST_ID(PM_RUNTIME_TYPE_INTF), /**< the id = 0, is means invalid */
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_SPI_APB,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_VOP = PM_RUNTIME_TYPE_TO_FIRST_ID(PM_RUNTIME_TYPE_DISPLAY),
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_MIPI,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_I2S = PM_RUNTIME_TYPE_TO_FIRST_ID(PM_RUNTIME_TYPE_AUDIO),
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_I2S1,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_I2S2,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_ADC,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_DMA,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_USB = PM_RUNTIME_TYPE_TO_FIRST_ID(PM_RUNTIME_TYPE_HS_INTF),
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_SDIO,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART0 = PM_RUNTIME_TYPE_TO_FIRST_ID(PM_RUNTIME_TYPE_UART),
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART1,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART2,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART3,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART4,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART5,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART6,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART7,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART8,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_UART9,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_I2C0 = PM_RUNTIME_TYPE_TO_FIRST_ID(PM_RUNTIME_TYPE_I2C),
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_I2C1,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_I2C2,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_I2C3,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_I2C4,
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_I2C5,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_SPI = PM_RUNTIME_TYPE_TO_FIRST_ID(PM_RUNTIME_TYPE_SPI),
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_CIF = PM_RUNTIME_TYPE_TO_FIRST_ID(PM_RUNTIME_TYPE_CIF),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PM_RUNTIME_ID_END,
 | 
				
			||||||
 | 
					} ePM_RUNTIME_ID;
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					  * @brief  GMAC HW Information Definition
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					struct HAL_GMAC_DEV {
 | 
				
			||||||
 | 
					    struct GMAC_REG *pReg;
 | 
				
			||||||
 | 
					    eCLOCK_Name clkID;
 | 
				
			||||||
 | 
					    uint32_t clkGateID;
 | 
				
			||||||
 | 
					    eCLOCK_Name pclkID;
 | 
				
			||||||
 | 
					    uint32_t pclkGateID;
 | 
				
			||||||
 | 
					    IRQn_Type irqNum;
 | 
				
			||||||
 | 
					    ePM_RUNTIME_ID runtimeID;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					/** @defgroup GMAC_Public_Function_Declare Public Function Declare
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_Init(struct GMAC_HANDLE *pGMAC, struct GMAC_REG *pReg,
 | 
				
			||||||
 | 
					                         uint32_t freq, eGMAC_PHY_Interface interface,
 | 
				
			||||||
 | 
					                         bool extClk);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_DeInit(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_Start(struct GMAC_HANDLE *pGMAC, uint8_t *addr);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_Stop(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					void HAL_GMAC_EnableDmaIRQ(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					void HAL_GMAC_DisableDmaIRQ(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_DMATxDescInit(struct GMAC_HANDLE *pGMAC,
 | 
				
			||||||
 | 
					                                  struct GMAC_Desc *txDescs,
 | 
				
			||||||
 | 
					                                  uint8_t *txBuff, uint32_t txBuffCount);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_DMARxDescInit(struct GMAC_HANDLE *pGMAC,
 | 
				
			||||||
 | 
					                                  struct GMAC_Desc *rxDescs,
 | 
				
			||||||
 | 
					                                  uint8_t *rxBuff, uint32_t rxBuffCount);
 | 
				
			||||||
 | 
					eGMAC_IRQ_Status HAL_GMAC_IRQHandler(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_AdjustLink(struct GMAC_HANDLE *pGMAC, int32_t txDelay,
 | 
				
			||||||
 | 
					                               int32_t rxDelay);
 | 
				
			||||||
 | 
					uint32_t HAL_GMAC_GetTXIndex(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					uint32_t HAL_GMAC_GetRXIndex(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					uint8_t *HAL_GMAC_GetTXBuffer(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					uint8_t *HAL_GMAC_GetRXBuffer(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_Send(struct GMAC_HANDLE *pGMAC,
 | 
				
			||||||
 | 
					                         void *packet, uint32_t length);
 | 
				
			||||||
 | 
					uint8_t *HAL_GMAC_Recv(struct GMAC_HANDLE *pGMAC, int32_t *length);
 | 
				
			||||||
 | 
					void HAL_GMAC_CleanRX(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					void HAL_GMAC_WriteHWAddr(struct GMAC_HANDLE *pGMAC, uint8_t *enetAddr);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_PHYInit(struct GMAC_HANDLE *pGMAC,
 | 
				
			||||||
 | 
					                            struct GMAC_PHY_Config *config);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_PHYStartup(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_PHYUpdateLink(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_PHYParseLink(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					int32_t HAL_GMAC_MDIORead(struct GMAC_HANDLE *pGMAC, int32_t mdioAddr,
 | 
				
			||||||
 | 
					                          int32_t mdioReg);
 | 
				
			||||||
 | 
					HAL_Status HAL_GMAC_MDIOWrite(struct GMAC_HANDLE *pGMAC, int32_t mdioAddr,
 | 
				
			||||||
 | 
					                              int32_t mdioReg, uint16_t mdioVal);
 | 
				
			||||||
 | 
					void HAL_GMAC_SetToRGMII(struct GMAC_HANDLE *pGMAC,
 | 
				
			||||||
 | 
					                         int32_t txDelay, int32_t rxDelay);
 | 
				
			||||||
 | 
					void HAL_GMAC_SetToRMII(struct GMAC_HANDLE *pGMAC);
 | 
				
			||||||
 | 
					void HAL_GMAC_SetRGMIISpeed(struct GMAC_HANDLE *pGMAC, int32_t speed);
 | 
				
			||||||
 | 
					void HAL_GMAC_SetRMIISpeed(struct GMAC_HANDLE *pGMAC, int32_t speed);
 | 
				
			||||||
 | 
					void HAL_GMAC_SetExtclkSrc(struct GMAC_HANDLE *pGMAC, bool extClk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,169 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					  * @{
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup GPIO
 | 
				
			||||||
 | 
					  * @{
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __HAL_GPIO_H
 | 
				
			||||||
 | 
					#define __HAL_GPIO_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					#include "hal_pinctrl.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					/** @defgroup GPIO_Exported_Definition_Group1 Basic Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef GPIO_VER_ID
 | 
				
			||||||
 | 
					#define GPIO_VER_ID (0U)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define PIN_NUMBER_PER_BANK (32)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GPIO_PIN_SHIFT  (0) /**< Bits 0-4: GPIO Pin number: 0 - 31 */
 | 
				
			||||||
 | 
					#define GPIO_PIN_MASK   (0x1f << GPIO_PIN_SHIFT)
 | 
				
			||||||
 | 
					#define GPIO_BANK_SHIFT (5) /**< Bits 5-7: GPIO Port number: 0 - 7 */
 | 
				
			||||||
 | 
					#define GPIO_BANK_MASK  (0x7 << GPIO_BANK_SHIFT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define BANK_PIN(BANK, PIN) ((((BANK) << GPIO_BANK_SHIFT) & GPIO_BANK_MASK) + (((PIN) << GPIO_PIN_SHIFT) & GPIO_PIN_MASK))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					/** GPIO pin level definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GPIO_LOW,
 | 
				
			||||||
 | 
					    GPIO_HIGH
 | 
				
			||||||
 | 
					} eGPIO_pinLevel;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** GPIO pin direction definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GPIO_IN,
 | 
				
			||||||
 | 
					    GPIO_OUT
 | 
				
			||||||
 | 
					} eGPIO_pinDirection;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** GPIO pin debounce definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GPIO_DEBOUNCE_DIS,
 | 
				
			||||||
 | 
					    GPIO_DEBOUNCE_EN
 | 
				
			||||||
 | 
					} eGPIO_pinDebounce;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** GPIO pin interrupt enable definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GPIO_INT_DISABLE,
 | 
				
			||||||
 | 
					    GPIO_INT_ENABLE
 | 
				
			||||||
 | 
					} eGPIO_intEnable;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** GPIO pin interrupt type definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GPIO_INT_TYPE_NONE         = 0x00000000,
 | 
				
			||||||
 | 
					    GPIO_INT_TYPE_EDGE_RISING  = 0x00000001,
 | 
				
			||||||
 | 
					    GPIO_INT_TYPE_EDGE_FALLING = 0x00000002,
 | 
				
			||||||
 | 
					    GPIO_INT_TYPE_EDGE_BOTH    = (GPIO_INT_TYPE_EDGE_FALLING | GPIO_INT_TYPE_EDGE_RISING),
 | 
				
			||||||
 | 
					    GPIO_INT_TYPE_LEVEL_HIGH   = 0x00000004,
 | 
				
			||||||
 | 
					    GPIO_INT_TYPE_LEVEL_LOW    = 0x00000008,
 | 
				
			||||||
 | 
					    GPIO_INT_TYPE_LEVEL_MASK   = (GPIO_INT_TYPE_LEVEL_LOW | GPIO_INT_TYPE_LEVEL_HIGH),
 | 
				
			||||||
 | 
					    GPIO_INT_TYPE_SENSE_MASK   = 0x0000000f,
 | 
				
			||||||
 | 
					    GPIO_INT_TYPE_DEFAULT      = GPIO_INT_TYPE_SENSE_MASK,
 | 
				
			||||||
 | 
					} eGPIO_intType;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** GPIO pin interrupt mode definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GPIO_INT_MODE_EDGE_RISING,
 | 
				
			||||||
 | 
					    GPIO_INT_MODE_EDGE_FALLING,
 | 
				
			||||||
 | 
					    GPIO_INT_MODE_EDGE_RISING_FALLING,
 | 
				
			||||||
 | 
					    GPIO_INT_MODE_LEVEL_HIGH,
 | 
				
			||||||
 | 
					    GPIO_INT_MODE_LEVEL_LOW,
 | 
				
			||||||
 | 
					    GPIO_INT_MODE_INVALID
 | 
				
			||||||
 | 
					} eGPIO_intMode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** GPIO pin virtual model definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GPIO_VIRTUAL_MODEL_OS_A,
 | 
				
			||||||
 | 
					    GPIO_VIRTUAL_MODEL_OS_B,
 | 
				
			||||||
 | 
					    GPIO_VIRTUAL_MODEL_OS_C,
 | 
				
			||||||
 | 
					    GPIO_VIRTUAL_MODEL_OS_D,
 | 
				
			||||||
 | 
					} eGPIO_VirtualModel;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define IS_GPIO_PIN_DIR(ACTION)   (((ACTION) == GPIO_IN) || ((ACTION) == GPIO_OUT))
 | 
				
			||||||
 | 
					#define IS_GPIO_PIN_LEVEL(ACTION) (((ACTION) == GPIO_LOW) || ((ACTION) == GPIO_HIGH))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define IS_GPIO_PIN(PIN)      ((PIN) != 0x00000000U)
 | 
				
			||||||
 | 
					#define IS_GPIO_HIGH_PIN(PIN) IS_GPIO_PIN(((PIN) & 0xFFFF0000U))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define IS_GET_GPIO_PIN(PIN) (((PIN) == GPIO_PIN_A0) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_A1) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_A2) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_A3) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_A4) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_A5) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_A6) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_A7) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_B0) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_B1) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_B2) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_B3) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_B4) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_B5) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_B6) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_B7) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_C0) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_C1) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_C2) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_C3) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_C4) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_C5) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_C6) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_C7) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_D0) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_D1) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_D2) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_D3) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_D4) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_D5) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_D6) || \
 | 
				
			||||||
 | 
					                              ((PIN) == GPIO_PIN_D7))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					/** @defgroup GPIO_Exported_Definition_Group2 Public Functions Declare.
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					eGPIO_pinDirection HAL_GPIO_GetPinDirection(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin);
 | 
				
			||||||
 | 
					eGPIO_pinLevel HAL_GPIO_GetPinLevel(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin);
 | 
				
			||||||
 | 
					eGPIO_pinLevel HAL_GPIO_GetPinData(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin);
 | 
				
			||||||
 | 
					uint32_t HAL_GPIO_GetBankLevel(struct GPIO_REG *pGPIO);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetPinLevel(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin, eGPIO_pinLevel level);
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetPinDirection(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin, eGPIO_pinDirection direction);
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetIntType(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin, eGPIO_intType mode);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetPinsLevel(struct GPIO_REG *pGPIO, uint32_t mPins, eGPIO_pinLevel level);
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetPinsDirection(struct GPIO_REG *pGPIO, uint32_t mPins, eGPIO_pinDirection direction);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void HAL_GPIO_EnableIRQ(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin);
 | 
				
			||||||
 | 
					void HAL_GPIO_DisableIRQ(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin);
 | 
				
			||||||
 | 
					void HAL_GPIO_IRQHandler(struct GPIO_REG *pGPIO, eGPIO_bankId bank);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAL_GPIO_VIRTUAL_MODEL_FEATURE_ENABLED
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_EnableVirtualModel(struct GPIO_REG *pGPIO);
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_DisableVirtualModel(struct GPIO_REG *pGPIO);
 | 
				
			||||||
 | 
					HAL_Status HAL_GPIO_SetVirtualModel(struct GPIO_REG *pGPIO, ePINCTRL_GPIO_PINS pin, eGPIO_VirtualModel vmodel);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* The parameter pin for this function is special, it's 0~31. */
 | 
				
			||||||
 | 
					void HAL_GPIO_IRQDispatch(eGPIO_bankId bank, uint32_t pin);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,181 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef _HAL_LIST_H_
 | 
				
			||||||
 | 
					#define _HAL_LIST_H_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** double list struct */
 | 
				
			||||||
 | 
					struct HAL_LIST_NODE {
 | 
				
			||||||
 | 
					    struct HAL_LIST_NODE *next;
 | 
				
			||||||
 | 
					    struct HAL_LIST_NODE *prev;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef struct HAL_LIST_NODE HAL_LIST;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief cast a member of a structure out to the containing structure
 | 
				
			||||||
 | 
					 * @param ptr:    the pointer to the member.
 | 
				
			||||||
 | 
					 * @param type:   the type of the container struct this is embedded in.
 | 
				
			||||||
 | 
					 * @param member: the name of the member within the struct.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define HAL_CONTAINER_OF(ptr, type, member) \
 | 
				
			||||||
 | 
					    ((type *)((char *)(ptr) - (unsigned long)(&((type *)0)->member)))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief initialize a list object
 | 
				
			||||||
 | 
					 * @param object: object itself.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define HAL_LIST_OBJECT_INIT(object) { &(object), &(object) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define HAL_LIST_HEAD_INIT(name) { &(name), &(name) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief initialize a list head
 | 
				
			||||||
 | 
					 * @param name: list name..
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define HAL_LIST_HEAD(name) \
 | 
				
			||||||
 | 
					    struct HAL_LIST_NODE name = HAL_LIST_HEAD_INIT(name)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief initialize a list
 | 
				
			||||||
 | 
					 * @param l: list to be initialized
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static inline void HAL_LIST_Init(HAL_LIST *l)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    l->next = l->prev = l;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief insert a node after a list
 | 
				
			||||||
 | 
					 * @param l: list to insert it
 | 
				
			||||||
 | 
					 * @param n: new node to be inserted
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static inline void HAL_LIST_InsertAfter(HAL_LIST *l, HAL_LIST *n)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    l->next->prev = n;
 | 
				
			||||||
 | 
					    n->next = l->next;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    l->next = n;
 | 
				
			||||||
 | 
					    n->prev = l;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief insert a node before a list
 | 
				
			||||||
 | 
					 * @param n: new node to be inserted
 | 
				
			||||||
 | 
					 * @param l: list to insert it
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static inline void HAL_LIST_InsertBefore(HAL_LIST *l, HAL_LIST *n)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    l->prev->next = n;
 | 
				
			||||||
 | 
					    n->prev = l->prev;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    l->prev = n;
 | 
				
			||||||
 | 
					    n->next = l;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief remove node from list.
 | 
				
			||||||
 | 
					 * @param n: the node to remove from the list.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static inline void HAL_LIST_Remove(HAL_LIST *n)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    n->next->prev = n->prev;
 | 
				
			||||||
 | 
					    n->prev->next = n->next;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    n->next = n->prev = n;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief tests whether a list is empty
 | 
				
			||||||
 | 
					 * @param l: the list to test.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static inline int HAL_LIST_IsEmpty(const HAL_LIST *l)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return l->next == l;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief get the list length
 | 
				
			||||||
 | 
					 * @param l: the list to get.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					static inline uint32_t HAL_LIST_Len(const HAL_LIST *l)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    uint32_t len = 0;
 | 
				
			||||||
 | 
					    const HAL_LIST *p = l;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    while (p->next != l) {
 | 
				
			||||||
 | 
					        p = p->next;
 | 
				
			||||||
 | 
					        len++;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return len;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief get the struct for this entry
 | 
				
			||||||
 | 
					 * @param node: the entry point
 | 
				
			||||||
 | 
					 * @param type: the type of structure
 | 
				
			||||||
 | 
					 * @param member: the name of list in structure
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define HAL_LIST_ENTRY(node, type, member) \
 | 
				
			||||||
 | 
					    HAL_CONTAINER_OF(node, type, member)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief iterate over a list
 | 
				
			||||||
 | 
					 * @param pos:  the rt_list_t * to use as a loop cursor.
 | 
				
			||||||
 | 
					 * @param head: the head for your list.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define HAL_LIST_FOR_EACH(pos, head) \
 | 
				
			||||||
 | 
					    for (pos = (head)->next; pos != (head); pos = pos->next)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief iterate over a list safe against removal of list entry
 | 
				
			||||||
 | 
					 * @param pos:  the rt_list_t * to use as a loop cursor.
 | 
				
			||||||
 | 
					 * @param n:    another rt_list_t * to use as temporary storage
 | 
				
			||||||
 | 
					 * @param head: the head for your list.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define HAL_LIST_FOR_EACH_SAFE(pos, n, head)               \
 | 
				
			||||||
 | 
					    for (pos = (head)->next, n = pos->next; pos != (head); \
 | 
				
			||||||
 | 
					        pos = n, n = pos->next)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief   iterate over list of given type
 | 
				
			||||||
 | 
					 * @param   pos:    the type * to use as a loop cursor.
 | 
				
			||||||
 | 
					 * @param   head:   the head for your list.
 | 
				
			||||||
 | 
					 * @param   member: the name of the list_struct within the struct.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define HAL_LIST_FOR_EACH_ENTRY(pos, head, member)                     \
 | 
				
			||||||
 | 
					    for (pos = HAL_LIST_ENTRY((head)->next, __typeof__(*pos), member); \
 | 
				
			||||||
 | 
					         &pos->member != (head);                                       \
 | 
				
			||||||
 | 
					         pos = HAL_LIST_ENTRY(pos->member.next, __typeof__(*pos), member))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief   iterate over list of given type safe against removal of list entry
 | 
				
			||||||
 | 
					 * @param   pos:    the type * to use as a loop cursor.
 | 
				
			||||||
 | 
					 * @param   n:      another type * to use as temporary storage
 | 
				
			||||||
 | 
					 * @param   head:   the head for your list.
 | 
				
			||||||
 | 
					 * @param   member: the name of the list_struct within the struct.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define HAL_LIST_FOR_EACH_ENTRY_SAFE(pos, n, head, member)               \
 | 
				
			||||||
 | 
					    for (pos = HAL_LIST_ENTRY((head)->next, __typeof__(*pos), member),   \
 | 
				
			||||||
 | 
					         n = HAL_LIST_ENTRY(pos->member.next, __typeof__(*pos), member); \
 | 
				
			||||||
 | 
					         &pos->member != (head);                                         \
 | 
				
			||||||
 | 
					         pos = n, n = HAL_LIST_ENTRY(n->member.next, __typeof__(*n), member))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * @brief   get the first element from a list
 | 
				
			||||||
 | 
					 * @param   ptr:    the list head to take the element from.
 | 
				
			||||||
 | 
					 * @param   type:   the type of the struct this is embedded in.
 | 
				
			||||||
 | 
					 * @param   member: the name of the list_struct within the struct.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Note, that list is expected to be not empty.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					#define HAL_LIST_FIRST_ENTRY(ptr, type, member) \
 | 
				
			||||||
 | 
					    HAL_LIST_ENTRY((ptr)->next, type, member)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,697 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup PINCTRL
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __HAL_PINCTRL_H__
 | 
				
			||||||
 | 
					#define __HAL_PINCTRL_H__
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					/** @defgroup PINCTRL_Exported_Definition_Group1 Basic Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** PINCTRL IOFUNC Select definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    IOFUNC_SEL_M0,
 | 
				
			||||||
 | 
					    IOFUNC_SEL_M1,
 | 
				
			||||||
 | 
					    IOFUNC_SEL_M2,
 | 
				
			||||||
 | 
					} eIOFUNC_SEL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					#if defined(GPIO0)
 | 
				
			||||||
 | 
					    GPIO0_A0 = 0,
 | 
				
			||||||
 | 
					    GPIO0_A1,
 | 
				
			||||||
 | 
					    GPIO0_A2,
 | 
				
			||||||
 | 
					    GPIO0_A3,
 | 
				
			||||||
 | 
					    GPIO0_A4,
 | 
				
			||||||
 | 
					    GPIO0_A5,
 | 
				
			||||||
 | 
					    GPIO0_A6,
 | 
				
			||||||
 | 
					    GPIO0_A7,
 | 
				
			||||||
 | 
					    GPIO0_B0 = 8,
 | 
				
			||||||
 | 
					    GPIO0_B1,
 | 
				
			||||||
 | 
					    GPIO0_B2,
 | 
				
			||||||
 | 
					    GPIO0_B3,
 | 
				
			||||||
 | 
					    GPIO0_B4,
 | 
				
			||||||
 | 
					    GPIO0_B5,
 | 
				
			||||||
 | 
					    GPIO0_B6,
 | 
				
			||||||
 | 
					    GPIO0_B7,
 | 
				
			||||||
 | 
					    GPIO0_C0 = 16,
 | 
				
			||||||
 | 
					    GPIO0_C1,
 | 
				
			||||||
 | 
					    GPIO0_C2,
 | 
				
			||||||
 | 
					    GPIO0_C3,
 | 
				
			||||||
 | 
					    GPIO0_C4,
 | 
				
			||||||
 | 
					    GPIO0_C5,
 | 
				
			||||||
 | 
					    GPIO0_C6,
 | 
				
			||||||
 | 
					    GPIO0_C7,
 | 
				
			||||||
 | 
					    GPIO0_D0 = 24,
 | 
				
			||||||
 | 
					    GPIO0_D1,
 | 
				
			||||||
 | 
					    GPIO0_D2,
 | 
				
			||||||
 | 
					    GPIO0_D3,
 | 
				
			||||||
 | 
					    GPIO0_D4,
 | 
				
			||||||
 | 
					    GPIO0_D5,
 | 
				
			||||||
 | 
					    GPIO0_D6,
 | 
				
			||||||
 | 
					    GPIO0_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if defined(GPIO1)
 | 
				
			||||||
 | 
					    GPIO1_A0 = 32,
 | 
				
			||||||
 | 
					    GPIO1_A1,
 | 
				
			||||||
 | 
					    GPIO1_A2,
 | 
				
			||||||
 | 
					    GPIO1_A3,
 | 
				
			||||||
 | 
					    GPIO1_A4,
 | 
				
			||||||
 | 
					    GPIO1_A5,
 | 
				
			||||||
 | 
					    GPIO1_A6,
 | 
				
			||||||
 | 
					    GPIO1_A7,
 | 
				
			||||||
 | 
					    GPIO1_B0 = 40,
 | 
				
			||||||
 | 
					    GPIO1_B1,
 | 
				
			||||||
 | 
					    GPIO1_B2,
 | 
				
			||||||
 | 
					    GPIO1_B3,
 | 
				
			||||||
 | 
					    GPIO1_B4,
 | 
				
			||||||
 | 
					    GPIO1_B5,
 | 
				
			||||||
 | 
					    GPIO1_B6,
 | 
				
			||||||
 | 
					    GPIO1_B7,
 | 
				
			||||||
 | 
					    GPIO1_C0 = 48,
 | 
				
			||||||
 | 
					    GPIO1_C1,
 | 
				
			||||||
 | 
					    GPIO1_C2,
 | 
				
			||||||
 | 
					    GPIO1_C3,
 | 
				
			||||||
 | 
					    GPIO1_C4,
 | 
				
			||||||
 | 
					    GPIO1_C5,
 | 
				
			||||||
 | 
					    GPIO1_C6,
 | 
				
			||||||
 | 
					    GPIO1_C7,
 | 
				
			||||||
 | 
					    GPIO1_D0 = 56,
 | 
				
			||||||
 | 
					    GPIO1_D1,
 | 
				
			||||||
 | 
					    GPIO1_D2,
 | 
				
			||||||
 | 
					    GPIO1_D3,
 | 
				
			||||||
 | 
					    GPIO1_D4,
 | 
				
			||||||
 | 
					    GPIO1_D5,
 | 
				
			||||||
 | 
					    GPIO1_D6,
 | 
				
			||||||
 | 
					    GPIO1_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if defined(GPIO2)
 | 
				
			||||||
 | 
					    GPIO2_A0 = 64,
 | 
				
			||||||
 | 
					    GPIO2_A1,
 | 
				
			||||||
 | 
					    GPIO2_A2,
 | 
				
			||||||
 | 
					    GPIO2_A3,
 | 
				
			||||||
 | 
					    GPIO2_A4,
 | 
				
			||||||
 | 
					    GPIO2_A5,
 | 
				
			||||||
 | 
					    GPIO2_A6,
 | 
				
			||||||
 | 
					    GPIO2_A7,
 | 
				
			||||||
 | 
					    GPIO2_B0 = 72,
 | 
				
			||||||
 | 
					    GPIO2_B1,
 | 
				
			||||||
 | 
					    GPIO2_B2,
 | 
				
			||||||
 | 
					    GPIO2_B3,
 | 
				
			||||||
 | 
					    GPIO2_B4,
 | 
				
			||||||
 | 
					    GPIO2_B5,
 | 
				
			||||||
 | 
					    GPIO2_B6,
 | 
				
			||||||
 | 
					    GPIO2_B7,
 | 
				
			||||||
 | 
					    GPIO2_C0 = 80,
 | 
				
			||||||
 | 
					    GPIO2_C1,
 | 
				
			||||||
 | 
					    GPIO2_C2,
 | 
				
			||||||
 | 
					    GPIO2_C3,
 | 
				
			||||||
 | 
					    GPIO2_C4,
 | 
				
			||||||
 | 
					    GPIO2_C5,
 | 
				
			||||||
 | 
					    GPIO2_C6,
 | 
				
			||||||
 | 
					    GPIO2_C7,
 | 
				
			||||||
 | 
					    GPIO2_D0 = 88,
 | 
				
			||||||
 | 
					    GPIO2_D1,
 | 
				
			||||||
 | 
					    GPIO2_D2,
 | 
				
			||||||
 | 
					    GPIO2_D3,
 | 
				
			||||||
 | 
					    GPIO2_D4,
 | 
				
			||||||
 | 
					    GPIO2_D5,
 | 
				
			||||||
 | 
					    GPIO2_D6,
 | 
				
			||||||
 | 
					    GPIO2_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if defined(GPIO3)
 | 
				
			||||||
 | 
					    GPIO3_A0 = 96,
 | 
				
			||||||
 | 
					    GPIO3_A1,
 | 
				
			||||||
 | 
					    GPIO3_A2,
 | 
				
			||||||
 | 
					    GPIO3_A3,
 | 
				
			||||||
 | 
					    GPIO3_A4,
 | 
				
			||||||
 | 
					    GPIO3_A5,
 | 
				
			||||||
 | 
					    GPIO3_A6,
 | 
				
			||||||
 | 
					    GPIO3_A7,
 | 
				
			||||||
 | 
					    GPIO3_B0 = 104,
 | 
				
			||||||
 | 
					    GPIO3_B1,
 | 
				
			||||||
 | 
					    GPIO3_B2,
 | 
				
			||||||
 | 
					    GPIO3_B3,
 | 
				
			||||||
 | 
					    GPIO3_B4,
 | 
				
			||||||
 | 
					    GPIO3_B5,
 | 
				
			||||||
 | 
					    GPIO3_B6,
 | 
				
			||||||
 | 
					    GPIO3_B7,
 | 
				
			||||||
 | 
					    GPIO3_C0 = 112,
 | 
				
			||||||
 | 
					    GPIO3_C1,
 | 
				
			||||||
 | 
					    GPIO3_C2,
 | 
				
			||||||
 | 
					    GPIO3_C3,
 | 
				
			||||||
 | 
					    GPIO3_C4,
 | 
				
			||||||
 | 
					    GPIO3_C5,
 | 
				
			||||||
 | 
					    GPIO3_C6,
 | 
				
			||||||
 | 
					    GPIO3_C7,
 | 
				
			||||||
 | 
					    GPIO3_D0 = 120,
 | 
				
			||||||
 | 
					    GPIO3_D1,
 | 
				
			||||||
 | 
					    GPIO3_D2,
 | 
				
			||||||
 | 
					    GPIO3_D3,
 | 
				
			||||||
 | 
					    GPIO3_D4,
 | 
				
			||||||
 | 
					    GPIO3_D5,
 | 
				
			||||||
 | 
					    GPIO3_D6,
 | 
				
			||||||
 | 
					    GPIO3_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if defined(GPIO4)
 | 
				
			||||||
 | 
					    GPIO4_A0 = 128,
 | 
				
			||||||
 | 
					    GPIO4_A1,
 | 
				
			||||||
 | 
					    GPIO4_A2,
 | 
				
			||||||
 | 
					    GPIO4_A3,
 | 
				
			||||||
 | 
					    GPIO4_A4,
 | 
				
			||||||
 | 
					    GPIO4_A5,
 | 
				
			||||||
 | 
					    GPIO4_A6,
 | 
				
			||||||
 | 
					    GPIO4_A7,
 | 
				
			||||||
 | 
					    GPIO4_B0 = 136,
 | 
				
			||||||
 | 
					    GPIO4_B1,
 | 
				
			||||||
 | 
					    GPIO4_B2,
 | 
				
			||||||
 | 
					    GPIO4_B3,
 | 
				
			||||||
 | 
					    GPIO4_B4,
 | 
				
			||||||
 | 
					    GPIO4_B5,
 | 
				
			||||||
 | 
					    GPIO4_B6,
 | 
				
			||||||
 | 
					    GPIO4_B7,
 | 
				
			||||||
 | 
					    GPIO4_C0 = 144,
 | 
				
			||||||
 | 
					    GPIO4_C1,
 | 
				
			||||||
 | 
					    GPIO4_C2,
 | 
				
			||||||
 | 
					    GPIO4_C3,
 | 
				
			||||||
 | 
					    GPIO4_C4,
 | 
				
			||||||
 | 
					    GPIO4_C5,
 | 
				
			||||||
 | 
					    GPIO4_C6,
 | 
				
			||||||
 | 
					    GPIO4_C7,
 | 
				
			||||||
 | 
					    GPIO4_D0 = 152,
 | 
				
			||||||
 | 
					    GPIO4_D1,
 | 
				
			||||||
 | 
					    GPIO4_D2,
 | 
				
			||||||
 | 
					    GPIO4_D3,
 | 
				
			||||||
 | 
					    GPIO4_D4,
 | 
				
			||||||
 | 
					    GPIO4_D5,
 | 
				
			||||||
 | 
					    GPIO4_D6,
 | 
				
			||||||
 | 
					    GPIO4_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if defined(GPIO0_EXP)
 | 
				
			||||||
 | 
					    GPIO0_EXP_A0 = 160,
 | 
				
			||||||
 | 
					    GPIO0_EXP_A1,
 | 
				
			||||||
 | 
					    GPIO0_EXP_A2,
 | 
				
			||||||
 | 
					    GPIO0_EXP_A3,
 | 
				
			||||||
 | 
					    GPIO0_EXP_A4,
 | 
				
			||||||
 | 
					    GPIO0_EXP_A5,
 | 
				
			||||||
 | 
					    GPIO0_EXP_A6,
 | 
				
			||||||
 | 
					    GPIO0_EXP_A7,
 | 
				
			||||||
 | 
					    GPIO0_EXP_B0 = 168,
 | 
				
			||||||
 | 
					    GPIO0_EXP_B1,
 | 
				
			||||||
 | 
					    GPIO0_EXP_B2,
 | 
				
			||||||
 | 
					    GPIO0_EXP_B3,
 | 
				
			||||||
 | 
					    GPIO0_EXP_B4,
 | 
				
			||||||
 | 
					    GPIO0_EXP_B5,
 | 
				
			||||||
 | 
					    GPIO0_EXP_B6,
 | 
				
			||||||
 | 
					    GPIO0_EXP_B7,
 | 
				
			||||||
 | 
					    GPIO0_EXP_C0 = 176,
 | 
				
			||||||
 | 
					    GPIO0_EXP_C1,
 | 
				
			||||||
 | 
					    GPIO0_EXP_C2,
 | 
				
			||||||
 | 
					    GPIO0_EXP_C3,
 | 
				
			||||||
 | 
					    GPIO0_EXP_C4,
 | 
				
			||||||
 | 
					    GPIO0_EXP_C5,
 | 
				
			||||||
 | 
					    GPIO0_EXP_C6,
 | 
				
			||||||
 | 
					    GPIO0_EXP_C7,
 | 
				
			||||||
 | 
					    GPIO0_EXP_D0 = 184,
 | 
				
			||||||
 | 
					    GPIO0_EXP_D1,
 | 
				
			||||||
 | 
					    GPIO0_EXP_D2,
 | 
				
			||||||
 | 
					    GPIO0_EXP_D3,
 | 
				
			||||||
 | 
					    GPIO0_EXP_D4,
 | 
				
			||||||
 | 
					    GPIO0_EXP_D5,
 | 
				
			||||||
 | 
					    GPIO0_EXP_D6,
 | 
				
			||||||
 | 
					    GPIO0_EXP_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if defined(GPIO1_EXP)
 | 
				
			||||||
 | 
					    GPIO1_EXP_A0 = 192,
 | 
				
			||||||
 | 
					    GPIO1_EXP_A1,
 | 
				
			||||||
 | 
					    GPIO1_EXP_A2,
 | 
				
			||||||
 | 
					    GPIO1_EXP_A3,
 | 
				
			||||||
 | 
					    GPIO1_EXP_A4,
 | 
				
			||||||
 | 
					    GPIO1_EXP_A5,
 | 
				
			||||||
 | 
					    GPIO1_EXP_A6,
 | 
				
			||||||
 | 
					    GPIO1_EXP_A7,
 | 
				
			||||||
 | 
					    GPIO1_EXP_B0 = 200,
 | 
				
			||||||
 | 
					    GPIO1_EXP_B1,
 | 
				
			||||||
 | 
					    GPIO1_EXP_B2,
 | 
				
			||||||
 | 
					    GPIO1_EXP_B3,
 | 
				
			||||||
 | 
					    GPIO1_EXP_B4,
 | 
				
			||||||
 | 
					    GPIO1_EXP_B5,
 | 
				
			||||||
 | 
					    GPIO1_EXP_B6,
 | 
				
			||||||
 | 
					    GPIO1_EXP_B7,
 | 
				
			||||||
 | 
					    GPIO1_EXP_C0 = 208,
 | 
				
			||||||
 | 
					    GPIO1_EXP_C1,
 | 
				
			||||||
 | 
					    GPIO1_EXP_C2,
 | 
				
			||||||
 | 
					    GPIO1_EXP_C3,
 | 
				
			||||||
 | 
					    GPIO1_EXP_C4,
 | 
				
			||||||
 | 
					    GPIO1_EXP_C5,
 | 
				
			||||||
 | 
					    GPIO1_EXP_C6,
 | 
				
			||||||
 | 
					    GPIO1_EXP_C7,
 | 
				
			||||||
 | 
					    GPIO1_EXP_D0 = 216,
 | 
				
			||||||
 | 
					    GPIO1_EXP_D1,
 | 
				
			||||||
 | 
					    GPIO1_EXP_D2,
 | 
				
			||||||
 | 
					    GPIO1_EXP_D3,
 | 
				
			||||||
 | 
					    GPIO1_EXP_D4,
 | 
				
			||||||
 | 
					    GPIO1_EXP_D5,
 | 
				
			||||||
 | 
					    GPIO1_EXP_D6,
 | 
				
			||||||
 | 
					    GPIO1_EXP_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if defined(GPIO2_EXP)
 | 
				
			||||||
 | 
					    GPIO2_EXP_A0 = 224,
 | 
				
			||||||
 | 
					    GPIO2_EXP_A1,
 | 
				
			||||||
 | 
					    GPIO2_EXP_A2,
 | 
				
			||||||
 | 
					    GPIO2_EXP_A3,
 | 
				
			||||||
 | 
					    GPIO2_EXP_A4,
 | 
				
			||||||
 | 
					    GPIO2_EXP_A5,
 | 
				
			||||||
 | 
					    GPIO2_EXP_A6,
 | 
				
			||||||
 | 
					    GPIO2_EXP_A7,
 | 
				
			||||||
 | 
					    GPIO2_EXP_B0 = 232,
 | 
				
			||||||
 | 
					    GPIO2_EXP_B1,
 | 
				
			||||||
 | 
					    GPIO2_EXP_B2,
 | 
				
			||||||
 | 
					    GPIO2_EXP_B3,
 | 
				
			||||||
 | 
					    GPIO2_EXP_B4,
 | 
				
			||||||
 | 
					    GPIO2_EXP_B5,
 | 
				
			||||||
 | 
					    GPIO2_EXP_B6,
 | 
				
			||||||
 | 
					    GPIO2_EXP_B7,
 | 
				
			||||||
 | 
					    GPIO2_EXP_C0 = 240,
 | 
				
			||||||
 | 
					    GPIO2_EXP_C1,
 | 
				
			||||||
 | 
					    GPIO2_EXP_C2,
 | 
				
			||||||
 | 
					    GPIO2_EXP_C3,
 | 
				
			||||||
 | 
					    GPIO2_EXP_C4,
 | 
				
			||||||
 | 
					    GPIO2_EXP_C5,
 | 
				
			||||||
 | 
					    GPIO2_EXP_C6,
 | 
				
			||||||
 | 
					    GPIO2_EXP_C7,
 | 
				
			||||||
 | 
					    GPIO2_EXP_D0 = 248,
 | 
				
			||||||
 | 
					    GPIO2_EXP_D1,
 | 
				
			||||||
 | 
					    GPIO2_EXP_D2,
 | 
				
			||||||
 | 
					    GPIO2_EXP_D3,
 | 
				
			||||||
 | 
					    GPIO2_EXP_D4,
 | 
				
			||||||
 | 
					    GPIO2_EXP_D5,
 | 
				
			||||||
 | 
					    GPIO2_EXP_D6,
 | 
				
			||||||
 | 
					    GPIO2_EXP_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if defined(GPIO3_EXP)
 | 
				
			||||||
 | 
					    GPIO3_EXP_A0 = 256,
 | 
				
			||||||
 | 
					    GPIO3_EXP_A1,
 | 
				
			||||||
 | 
					    GPIO3_EXP_A2,
 | 
				
			||||||
 | 
					    GPIO3_EXP_A3,
 | 
				
			||||||
 | 
					    GPIO3_EXP_A4,
 | 
				
			||||||
 | 
					    GPIO3_EXP_A5,
 | 
				
			||||||
 | 
					    GPIO3_EXP_A6,
 | 
				
			||||||
 | 
					    GPIO3_EXP_A7,
 | 
				
			||||||
 | 
					    GPIO3_EXP_B0 = 264,
 | 
				
			||||||
 | 
					    GPIO3_EXP_B1,
 | 
				
			||||||
 | 
					    GPIO3_EXP_B2,
 | 
				
			||||||
 | 
					    GPIO3_EXP_B3,
 | 
				
			||||||
 | 
					    GPIO3_EXP_B4,
 | 
				
			||||||
 | 
					    GPIO3_EXP_B5,
 | 
				
			||||||
 | 
					    GPIO3_EXP_B6,
 | 
				
			||||||
 | 
					    GPIO3_EXP_B7,
 | 
				
			||||||
 | 
					    GPIO3_EXP_C0 = 272,
 | 
				
			||||||
 | 
					    GPIO3_EXP_C1,
 | 
				
			||||||
 | 
					    GPIO3_EXP_C2,
 | 
				
			||||||
 | 
					    GPIO3_EXP_C3,
 | 
				
			||||||
 | 
					    GPIO3_EXP_C4,
 | 
				
			||||||
 | 
					    GPIO3_EXP_C5,
 | 
				
			||||||
 | 
					    GPIO3_EXP_C6,
 | 
				
			||||||
 | 
					    GPIO3_EXP_C7,
 | 
				
			||||||
 | 
					    GPIO3_EXP_D0 = 280,
 | 
				
			||||||
 | 
					    GPIO3_EXP_D1,
 | 
				
			||||||
 | 
					    GPIO3_EXP_D2,
 | 
				
			||||||
 | 
					    GPIO3_EXP_D3,
 | 
				
			||||||
 | 
					    GPIO3_EXP_D4,
 | 
				
			||||||
 | 
					    GPIO3_EXP_D5,
 | 
				
			||||||
 | 
					    GPIO3_EXP_D6,
 | 
				
			||||||
 | 
					    GPIO3_EXP_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#if defined(GPIO4_EXP)
 | 
				
			||||||
 | 
					    GPIO4_EXP_A0 = 288,
 | 
				
			||||||
 | 
					    GPIO4_EXP_A1,
 | 
				
			||||||
 | 
					    GPIO4_EXP_A2,
 | 
				
			||||||
 | 
					    GPIO4_EXP_A3,
 | 
				
			||||||
 | 
					    GPIO4_EXP_A4,
 | 
				
			||||||
 | 
					    GPIO4_EXP_A5,
 | 
				
			||||||
 | 
					    GPIO4_EXP_A6,
 | 
				
			||||||
 | 
					    GPIO4_EXP_A7,
 | 
				
			||||||
 | 
					    GPIO4_EXP_B0 = 296,
 | 
				
			||||||
 | 
					    GPIO4_EXP_B1,
 | 
				
			||||||
 | 
					    GPIO4_EXP_B2,
 | 
				
			||||||
 | 
					    GPIO4_EXP_B3,
 | 
				
			||||||
 | 
					    GPIO4_EXP_B4,
 | 
				
			||||||
 | 
					    GPIO4_EXP_B5,
 | 
				
			||||||
 | 
					    GPIO4_EXP_B6,
 | 
				
			||||||
 | 
					    GPIO4_EXP_B7,
 | 
				
			||||||
 | 
					    GPIO4_EXP_C0 = 304,
 | 
				
			||||||
 | 
					    GPIO4_EXP_C1,
 | 
				
			||||||
 | 
					    GPIO4_EXP_C2,
 | 
				
			||||||
 | 
					    GPIO4_EXP_C3,
 | 
				
			||||||
 | 
					    GPIO4_EXP_C4,
 | 
				
			||||||
 | 
					    GPIO4_EXP_C5,
 | 
				
			||||||
 | 
					    GPIO4_EXP_C6,
 | 
				
			||||||
 | 
					    GPIO4_EXP_C7,
 | 
				
			||||||
 | 
					    GPIO4_EXP_D0 = 312,
 | 
				
			||||||
 | 
					    GPIO4_EXP_D1,
 | 
				
			||||||
 | 
					    GPIO4_EXP_D2,
 | 
				
			||||||
 | 
					    GPIO4_EXP_D3,
 | 
				
			||||||
 | 
					    GPIO4_EXP_D4,
 | 
				
			||||||
 | 
					    GPIO4_EXP_D5,
 | 
				
			||||||
 | 
					    GPIO4_EXP_D6,
 | 
				
			||||||
 | 
					    GPIO4_EXP_D7,
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					    GPIO_NUM_MAX
 | 
				
			||||||
 | 
					} ePINCTRL_PIN;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** PINCTRL IOMUX definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC0,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC1,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC2,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC3,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC4,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC5,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC6,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC7,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC8,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC9,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC10,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC11,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC12,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC13,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC14,
 | 
				
			||||||
 | 
					    PINCTRL_IOMUX_FUNC15
 | 
				
			||||||
 | 
					} ePINCTRL_iomuxFunc;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** PINCTRL PULL definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PINCTRL_PULL_OD,
 | 
				
			||||||
 | 
					    PINCTRL_PULL_UP,
 | 
				
			||||||
 | 
					    PINCTRL_PULL_DOWN,
 | 
				
			||||||
 | 
					    PINCTRL_PULL_KEEP
 | 
				
			||||||
 | 
					} ePINCTRL_pullMode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** PINCTRL Drive Strength definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PINCTRL_DRIVE_LEVEL0,
 | 
				
			||||||
 | 
					    PINCTRL_DRIVE_LEVEL1,
 | 
				
			||||||
 | 
					    PINCTRL_DRIVE_LEVEL2,
 | 
				
			||||||
 | 
					    PINCTRL_DRIVE_LEVEL3,
 | 
				
			||||||
 | 
					    PINCTRL_DRIVE_LEVEL4,
 | 
				
			||||||
 | 
					    PINCTRL_DRIVE_LEVEL5,
 | 
				
			||||||
 | 
					    PINCTRL_DRIVE_LEVEL6,
 | 
				
			||||||
 | 
					    PINCTRL_DRIVE_LEVEL7
 | 
				
			||||||
 | 
					} ePINCTRL_driveLevel;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** PINCTRL Slew Rate definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PINCTRL_SLEWRATE_SLOW,
 | 
				
			||||||
 | 
					    PINCTRL_SLEWRATE_FAST
 | 
				
			||||||
 | 
					} ePINCTRL_slewRate;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** PINCTRL Schmitt enable definition */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PINCTRL_SCHMITT_DIS,
 | 
				
			||||||
 | 
					    PINCTRL_SCHMITT_EN
 | 
				
			||||||
 | 
					} ePINCTRL_schmitt;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define FLAG_MUX  HAL_BIT(31)
 | 
				
			||||||
 | 
					#define FLAG_PUL  HAL_BIT(30)
 | 
				
			||||||
 | 
					#define FLAG_DRV  HAL_BIT(29)
 | 
				
			||||||
 | 
					#define FLAG_SRT  HAL_BIT(28)
 | 
				
			||||||
 | 
					#define FLAG_SMT  HAL_BIT(27)
 | 
				
			||||||
 | 
					#define SHIFT_MUX (0)
 | 
				
			||||||
 | 
					#define SHIFT_PUL (4)
 | 
				
			||||||
 | 
					#define SHIFT_DRV (8)
 | 
				
			||||||
 | 
					#define SHIFT_SRT (16)
 | 
				
			||||||
 | 
					#define SHIFT_SMT (18)
 | 
				
			||||||
 | 
					#define MASK_MUX  (0xFU << SHIFT_MUX)
 | 
				
			||||||
 | 
					#define MASK_PUL  (0xFU << SHIFT_PUL)
 | 
				
			||||||
 | 
					#define MASK_DRV  (0xFFU << SHIFT_DRV)
 | 
				
			||||||
 | 
					#define MASK_SRT  (0x3U << SHIFT_SRT)
 | 
				
			||||||
 | 
					#define MASK_SMT  (0x3U << SHIFT_SMT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @brief  PIN Configuration Mode
 | 
				
			||||||
 | 
					 *  Elements values convention: gggg g000 0000 ttrr dddd dddd pppp xxxx
 | 
				
			||||||
 | 
					 *      - ggggg  : Flag to set Mux/Pull/Drive/Slewrate/Schmitt
 | 
				
			||||||
 | 
					 *      - tt  : Schmitt value
 | 
				
			||||||
 | 
					 *      - rr  : Slewrate value
 | 
				
			||||||
 | 
					 *      - dddddddd  : Drive value
 | 
				
			||||||
 | 
					 *      - pppp  : Pull value
 | 
				
			||||||
 | 
					 *      - xxxx  : Mux mode value
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC0   = (0x0 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC1   = (0x1 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC2   = (0x2 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC3   = (0x3 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC4   = (0x4 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC5   = (0x5 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC6   = (0x6 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC7   = (0x7 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC8   = (0x8 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC9   = (0x9 << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC10  = (0xa << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC11  = (0xb << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC12  = (0xc << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC13  = (0xd << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC14  = (0xe << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_FUNC15  = (0xf << SHIFT_MUX | FLAG_MUX),
 | 
				
			||||||
 | 
					    PIN_CONFIG_MUX_DEFAULT = PIN_CONFIG_MUX_FUNC0,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PIN_CONFIG_PUL_NORMAL  = (0x1 << SHIFT_PUL | FLAG_PUL),
 | 
				
			||||||
 | 
					    PIN_CONFIG_PUL_DEFAULT = (0x0 << SHIFT_PUL | FLAG_PUL),
 | 
				
			||||||
 | 
					    PIN_CONFIG_PUL_UP      = PIN_CONFIG_PUL_DEFAULT,
 | 
				
			||||||
 | 
					    PIN_CONFIG_PUL_DOWN    = PIN_CONFIG_PUL_DEFAULT,
 | 
				
			||||||
 | 
					    PIN_CONFIG_PUL_KEEP    = PIN_CONFIG_PUL_DEFAULT,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PIN_CONFIG_DRV_LEVEL0        = (0x1 << SHIFT_DRV | FLAG_DRV),
 | 
				
			||||||
 | 
					    PIN_CONFIG_DRV_LEVEL1        = (0x3 << SHIFT_DRV | FLAG_DRV),
 | 
				
			||||||
 | 
					    PIN_CONFIG_DRV_LEVEL2        = (0x7 << SHIFT_DRV | FLAG_DRV),
 | 
				
			||||||
 | 
					    PIN_CONFIG_DRV_LEVEL3        = (0xf << SHIFT_DRV | FLAG_DRV),
 | 
				
			||||||
 | 
					    PIN_CONFIG_DRV_LEVEL4        = (0x1f << SHIFT_DRV | FLAG_DRV),
 | 
				
			||||||
 | 
					    PIN_CONFIG_DRV_LEVEL5        = (0x3f << SHIFT_DRV | FLAG_DRV),
 | 
				
			||||||
 | 
					    PIN_CONFIG_DRV_LEVEL_DEFAULT = PIN_CONFIG_DRV_LEVEL2,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PIN_CONFIG_SRT_SLOW    = (0x0 << SHIFT_SRT | FLAG_SRT),
 | 
				
			||||||
 | 
					    PIN_CONFIG_SRT_FAST    = (0x1 << SHIFT_SRT | FLAG_SRT),
 | 
				
			||||||
 | 
					    PIN_CONFIG_SRT_DEFAULT = PIN_CONFIG_SRT_SLOW,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PIN_CONFIG_SMT_DISABLE = (0x0 << SHIFT_SMT | FLAG_SMT),
 | 
				
			||||||
 | 
					    PIN_CONFIG_SMT_ENABLE  = (0x1 << SHIFT_SMT | FLAG_SMT),
 | 
				
			||||||
 | 
					    PIN_CONFIG_SMT_DEFAULT = PIN_CONFIG_SMT_DISABLE,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    PIN_CONFIG_MAX = 0xFFFFFFFFU,
 | 
				
			||||||
 | 
					} ePINCTRL_configParam;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GRF_MUX_INFO = 0,
 | 
				
			||||||
 | 
					    GRF_PUL_INFO,
 | 
				
			||||||
 | 
					    GRF_DRV_INFO,
 | 
				
			||||||
 | 
					    GRF_SRT_INFO,
 | 
				
			||||||
 | 
					    GRF_SMT_INFO,
 | 
				
			||||||
 | 
					    GRF_INFO_NUM
 | 
				
			||||||
 | 
					} ePIN_GRF_INFO_ID;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define PIN_BANK_CFG_FLAGS(chn, cnt, reg,                                                       \
 | 
				
			||||||
 | 
					                           offset0, bpp0, ppr0,                                                 \
 | 
				
			||||||
 | 
					                           offset1, bpp1, ppr1,                                                 \
 | 
				
			||||||
 | 
					                           offset2, bpp2, ppr2,                                                 \
 | 
				
			||||||
 | 
					                           offset3, bpp3, ppr3,                                                 \
 | 
				
			||||||
 | 
					                           offset4, bpp4, ppr4)                                                 \
 | 
				
			||||||
 | 
					    {                                                                                           \
 | 
				
			||||||
 | 
					        .channel = chn,                                                                         \
 | 
				
			||||||
 | 
					        .pinCount = cnt,                                                                        \
 | 
				
			||||||
 | 
					        .grfBase = reg,                                                                         \
 | 
				
			||||||
 | 
					        .GRFInfo[GRF_MUX_INFO] = { .offset = offset0, .bitsPerPin = bpp0, .pinsPerReg = ppr0 }, \
 | 
				
			||||||
 | 
					        .GRFInfo[GRF_PUL_INFO] = { .offset = offset1, .bitsPerPin = bpp1, .pinsPerReg = ppr1 }, \
 | 
				
			||||||
 | 
					        .GRFInfo[GRF_DRV_INFO] = { .offset = offset2, .bitsPerPin = bpp2, .pinsPerReg = ppr2 }, \
 | 
				
			||||||
 | 
					        .GRFInfo[GRF_SRT_INFO] = { .offset = offset3, .bitsPerPin = bpp3, .pinsPerReg = ppr3 }, \
 | 
				
			||||||
 | 
					        .GRFInfo[GRF_SMT_INFO] = { .offset = offset4, .bitsPerPin = bpp4, .pinsPerReg = ppr4 }, \
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup ePINCTRL_GPIO_PINS Pins Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    GPIO_PIN_A0 = 0x00000001U,  /*!< Pin 0 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_A1 = 0x00000002U,  /*!< Pin 1 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_A2 = 0x00000004U,  /*!< Pin 2 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_A3 = 0x00000008U,  /*!< Pin 3 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_A4 = 0x00000010U,  /*!< Pin 4 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_A5 = 0x00000020U,  /*!< Pin 5 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_A6 = 0x00000040U,  /*!< Pin 6 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_A7 = 0x00000080U,  /*!< Pin 7 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_B0 = 0x00000100U,  /*!< Pin 8 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_B1 = 0x00000200U,  /*!< Pin 9 selected    */
 | 
				
			||||||
 | 
					    GPIO_PIN_B2 = 0x00000400U,  /*!< Pin 10 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_B3 = 0x00000800U,  /*!< Pin 11 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_B4 = 0x00001000U,  /*!< Pin 12 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_B5 = 0x00002000U,  /*!< Pin 13 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_B6 = 0x00004000U,  /*!< Pin 14 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_B7 = 0x00008000U,  /*!< Pin 15 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_C0 = 0x00010000U,  /*!< Pin 16 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_C1 = 0x00020000U,  /*!< Pin 17 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_C2 = 0x00040000U,  /*!< Pin 18 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_C3 = 0x00080000U,  /*!< Pin 19 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_C4 = 0x00100000U,  /*!< Pin 20 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_C5 = 0x00200000U,  /*!< Pin 21 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_C6 = 0x00400000U,  /*!< Pin 22 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_C7 = 0x00800000U,  /*!< Pin 23 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_D0 = 0x01000000U,  /*!< Pin 24 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_D1 = 0x02000000U,  /*!< Pin 25 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_D2 = 0x04000000U,  /*!< Pin 26 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_D3 = 0x08000000U,  /*!< Pin 27 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_D4 = 0x10000000U,  /*!< Pin 28 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_D5 = 0x20000000U,  /*!< Pin 29 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_D6 = 0x40000000U,  /*!< Pin 30 selected   */
 | 
				
			||||||
 | 
					    GPIO_PIN_D7 = 0x80000000U,  /*!< Pin 31 selected   */
 | 
				
			||||||
 | 
					} ePINCTRL_GPIO_PINS;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GPIO_PIN_ALL (0xFFFFFFFFU)  /*!< All pins selected */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define ROUTE_VAL(v, s, m) (((v) << (s)) | (m) << ((s) + 16))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct PINCTRL_GRF_INFO {
 | 
				
			||||||
 | 
					    uint16_t offset;
 | 
				
			||||||
 | 
					    uint8_t bitsPerPin;
 | 
				
			||||||
 | 
					    uint8_t pinsPerReg;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct PINCTRL_MUX_RECAL_DATA {
 | 
				
			||||||
 | 
					    uint32_t reg;
 | 
				
			||||||
 | 
					    uint8_t bank;
 | 
				
			||||||
 | 
					    uint8_t pin;
 | 
				
			||||||
 | 
					    uint8_t bit;
 | 
				
			||||||
 | 
					    uint8_t mask;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct PINCTRL_MUX_ROUTE_DATA {
 | 
				
			||||||
 | 
					    uint32_t routeReg;
 | 
				
			||||||
 | 
					    uint32_t routeVal;
 | 
				
			||||||
 | 
					    uint32_t pin;
 | 
				
			||||||
 | 
					    uint8_t bank;
 | 
				
			||||||
 | 
					    uint8_t func;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct PINCTRL_BANK_INFO {
 | 
				
			||||||
 | 
					    struct PINCTRL_GRF_INFO GRFInfo[GRF_INFO_NUM];
 | 
				
			||||||
 | 
					    uint32_t grfBase;
 | 
				
			||||||
 | 
					    uint8_t pinCount;
 | 
				
			||||||
 | 
					    uint8_t channel;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct HAL_PINCTRL_DEV {
 | 
				
			||||||
 | 
					    const struct PINCTRL_BANK_INFO *banks;
 | 
				
			||||||
 | 
					    const struct PINCTRL_MUX_RECAL_DATA *muxRecalData;
 | 
				
			||||||
 | 
					    const struct PINCTRL_MUX_ROUTE_DATA *muxRouteData;
 | 
				
			||||||
 | 
					    uint8_t banksNum;
 | 
				
			||||||
 | 
					    uint8_t muxRecalDataNum;
 | 
				
			||||||
 | 
					    uint8_t muxRouteDataNum;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @brief  Rockchip pinctrl device struct define
 | 
				
			||||||
 | 
					 * Define a struct for pinctrl, including banks info, bank number,
 | 
				
			||||||
 | 
					 * and grf info about iomux offset, iomux bit info, drive/pull/
 | 
				
			||||||
 | 
					 * slewrate/schmitt offset and bit info.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					extern const struct HAL_PINCTRL_DEV g_pinDev;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					/** @defgroup PINCTRL_Public_Function_Declare Public Function Declare
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_Suspend(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_Resume(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_Init(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_DeInit(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_SetParam(eGPIO_bankId bank, uint32_t mPins, ePINCTRL_configParam param);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_SetIOMUX(eGPIO_bankId bank, uint32_t mPins, ePINCTRL_configParam param);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForCIF(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForEMMC(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForFLASH(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForFSPI(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForLCDC(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForMIPICSI(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForRGMII(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForGMAC0(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForGMAC1(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForSDIO(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForSDMMC0(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForCAN0(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForCAN1(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForCAN2(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForCAN3(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForCAN4(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForCAN5(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForI2C0(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForI2C1(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForI2C2(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForI2C3(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForI2C4(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForI2C5(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForI2S0(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForI2S1(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForI2S2(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM0(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM1(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM2(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM3(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM4(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM5(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM6(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM7(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM8(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM9(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM10(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForPWM11(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForSPI0(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForSPI1(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForSPI2(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForSPI3(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForSPI4(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForSPI5(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART0(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART1(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART2(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART3(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART4(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART5(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART6(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART7(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART8(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART9(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART10(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_PINCTRL_IOFuncSelForUART11(eIOFUNC_SEL mode);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif /* __HAL_PINCTRL_H__ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,62 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup RK_HAL_Driver
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @addtogroup TIMER
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef _HAL_TIMER_H_
 | 
				
			||||||
 | 
					#define _HAL_TIMER_H_
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "hal_def.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** MACRO Definition ******************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @defgroup TIMER_Exported_Definition_Group1 Basic Definition
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    TIMER_FREE_RUNNING = 0,
 | 
				
			||||||
 | 
					    TIMER_USER_DEFINED,
 | 
				
			||||||
 | 
					    TIMER_MODE_MAX
 | 
				
			||||||
 | 
					} eTIMER_MODE;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/***************************** Structure Definition **************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					/***************************** Function Declare ******************************/
 | 
				
			||||||
 | 
					/** @defgroup TIMER_Public_Function_Declare Public Function Declare
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Stop(struct TIMER_REG *pReg);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Start(struct TIMER_REG *pReg);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Stop_IT(struct TIMER_REG *pReg);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Start_IT(struct TIMER_REG *pReg);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_SetCount(struct TIMER_REG *pReg, uint64_t usTick);
 | 
				
			||||||
 | 
					uint64_t HAL_TIMER_GetCount(struct TIMER_REG *pReg);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER0_Handler(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER1_Handler(void);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_Init(struct TIMER_REG *pReg, eTIMER_MODE mode);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_SysTimerInit(struct TIMER_REG *pReg);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_DeInit(struct TIMER_REG *pReg);
 | 
				
			||||||
 | 
					HAL_Status HAL_TIMER_ClrInt(struct TIMER_REG *pReg);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| 
						 | 
					@ -0,0 +1,443 @@
 | 
				
			||||||
 | 
					/* SPDX-License-Identifier: BSD-3-Clause */
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2021 Rockchip Electronics Co., Ltd.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __SOC_H
 | 
				
			||||||
 | 
					#define __SOC_H
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					extern "C" {
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* IO definitions (access restrictions to peripheral registers) */
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					#define     __I     volatile             /*!< brief Defines 'read only' permissions */
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define     __I     volatile const       /*!< brief Defines 'read only' permissions */
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					#define     __O     volatile             /*!< brief Defines 'write only' permissions */
 | 
				
			||||||
 | 
					#define     __IO    volatile             /*!< brief Defines 'read / write' permissions */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* ================================================================================ */
 | 
				
			||||||
 | 
					/* ================                    DMA REQ                      =============== */
 | 
				
			||||||
 | 
					/* ================================================================================ */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    DMA_REQ_UART0_TX = 0,
 | 
				
			||||||
 | 
					    DMA_REQ_UART0_RX = 1,
 | 
				
			||||||
 | 
					    DMA_REQ_UART1_TX = 2,
 | 
				
			||||||
 | 
					    DMA_REQ_UART1_RX = 3,
 | 
				
			||||||
 | 
					    DMA_REQ_UART2_TX = 4,
 | 
				
			||||||
 | 
					    DMA_REQ_UART2_RX = 5,
 | 
				
			||||||
 | 
					    DMA_REQ_UART3_TX = 6,
 | 
				
			||||||
 | 
					    DMA_REQ_UART3_RX = 7,
 | 
				
			||||||
 | 
					    DMA_REQ_UART4_TX = 8,
 | 
				
			||||||
 | 
					    DMA_REQ_UART4_RX = 9,
 | 
				
			||||||
 | 
					    DMA_REQ_UART5_TX = 10,
 | 
				
			||||||
 | 
					    DMA_REQ_UART5_RX = 11,
 | 
				
			||||||
 | 
					    DMA_REQ_UART6_TX = 12,
 | 
				
			||||||
 | 
					    DMA_REQ_UART6_RX = 13,
 | 
				
			||||||
 | 
					    DMA_REQ_UART7_TX = 14,
 | 
				
			||||||
 | 
					    DMA_REQ_UART7_RX = 15,
 | 
				
			||||||
 | 
					    DMA_REQ_UART8_TX = 16,
 | 
				
			||||||
 | 
					    DMA_REQ_UART8_RX = 17,
 | 
				
			||||||
 | 
					    DMA_REQ_UART9_TX = 18,
 | 
				
			||||||
 | 
					    DMA_REQ_UART9_RX = 19,
 | 
				
			||||||
 | 
					    DMA_REQ_SPI0_TX = 20,
 | 
				
			||||||
 | 
					    DMA_REQ_SPI0_RX = 21,
 | 
				
			||||||
 | 
					    DMA_REQ_SPI1_TX = 22,
 | 
				
			||||||
 | 
					    DMA_REQ_SPI1_RX = 23,
 | 
				
			||||||
 | 
					    DMA_REQ_SPI2_TX = 24,
 | 
				
			||||||
 | 
					    DMA_REQ_SPI2_RX = 25,
 | 
				
			||||||
 | 
					    DMA_REQ_SPI3_TX = 26,
 | 
				
			||||||
 | 
					    DMA_REQ_SPI3_RX = 27,
 | 
				
			||||||
 | 
					} DMA_REQ_Type;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* ================================================================================ */
 | 
				
			||||||
 | 
					/* ================                       IRQ                      ================ */
 | 
				
			||||||
 | 
					/* ================================================================================ */
 | 
				
			||||||
 | 
					#ifdef HAL_MCU_CORE
 | 
				
			||||||
 | 
					#define INTMUX_IRQ_START_NUM      32
 | 
				
			||||||
 | 
					#define INTMUX_OUT_IRQ_START_NUM  0
 | 
				
			||||||
 | 
					#define INTMUX_NUM_INT_PER_OUT    64
 | 
				
			||||||
 | 
					#define INTMUX_NUM_GROUP_PER_CON  8
 | 
				
			||||||
 | 
					#define INTMUX_NUM_GROUP_PER_OUT  8
 | 
				
			||||||
 | 
					#define INTMUX_NUM_INT_PER_GROUP  8
 | 
				
			||||||
 | 
					#define NUM_EXT_INTERRUPTS        320
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef enum
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					/******  Platform Exceptions Numbers ***************************************************/
 | 
				
			||||||
 | 
					    NUM_INTERRUPTS         = 0,
 | 
				
			||||||
 | 
					    DMAC0_ABORT_IRQn       = 45,       /*!< DMAC0 Abort Interrupt       */
 | 
				
			||||||
 | 
					    DMAC0_IRQn             = 46,       /*!< DMAC0 Interrupt             */
 | 
				
			||||||
 | 
					    DMAC1_ABORT_IRQn       = 47,       /*!< DMAC1 Abort Interrupt       */
 | 
				
			||||||
 | 
					    DMAC1_IRQn             = 48,       /*!< DMAC1 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO0_IRQn             = 65,       /*!< GPIO0 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO1_IRQn             = 66,       /*!< GPIO1 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO2_IRQn             = 67,       /*!< GPIO2 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO3_IRQn             = 68,       /*!< GPIO3 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO4_IRQn             = 69,       /*!< GPIO4 Interrupt             */
 | 
				
			||||||
 | 
					    I2C0_IRQn              = 78,       /*!< I2C0 Interrupt              */
 | 
				
			||||||
 | 
					    I2C1_IRQn              = 79,       /*!< I2C1 Interrupt              */
 | 
				
			||||||
 | 
					    I2C2_IRQn              = 80,       /*!< I2C2 Interrupt              */
 | 
				
			||||||
 | 
					    I2C3_IRQn              = 81,       /*!< I2C3 Interrupt              */
 | 
				
			||||||
 | 
					    I2C4_IRQn              = 82,       /*!< I2C4 Interrupt              */
 | 
				
			||||||
 | 
					    I2C5_IRQn              = 83,       /*!< I2C5 Interrupt              */
 | 
				
			||||||
 | 
					    PWM_PMU_IRQn           = 114,      /*!< PWM_PMU Interrupt           */
 | 
				
			||||||
 | 
					    PWM1_IRQn              = 115,      /*!< PWM1 Interrupt              */
 | 
				
			||||||
 | 
					    PWM2_IRQn              = 116,      /*!< PWM2 Interrupt              */
 | 
				
			||||||
 | 
					    PWM3_IRQn              = 117,      /*!< PWM3 Interrupt              */
 | 
				
			||||||
 | 
					    PWM_PMU_PWR_IRQn       = 118,      /*!< PWM_PMU PWR Interrupt       */
 | 
				
			||||||
 | 
					    PWM1_PWR_IRQn          = 119,      /*!< PWM1 PWR Interrupt          */
 | 
				
			||||||
 | 
					    PWM2_PWR_IRQn          = 120,      /*!< PWM2 PWR Interrupt          */
 | 
				
			||||||
 | 
					    PWM3_PWR_IRQn          = 121,      /*!< PWM3 PWR Interrupt          */
 | 
				
			||||||
 | 
					    SARADC_IRQn            = 125,       /*!< SARADC Interrupt            */
 | 
				
			||||||
 | 
					    FSPI0_IRQn             = 133,      /*!< FSPI Interrupt              */
 | 
				
			||||||
 | 
					    SPI0_IRQn              = 135,      /*!< SPI0 Interrupt              */
 | 
				
			||||||
 | 
					    SPI1_IRQn              = 136,      /*!< SPI1 Interrupt              */
 | 
				
			||||||
 | 
					    SPI2_IRQn              = 137,      /*!< SPI2 Interrupt              */
 | 
				
			||||||
 | 
					    SPI3_IRQn              = 138,      /*!< SPI3 Interrupt              */
 | 
				
			||||||
 | 
					    TIMER0_IRQn            = 141,      /*!< TIMER0 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER1_IRQn            = 142,      /*!< TIMER1 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER2_IRQn            = 143,      /*!< TIMER2 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER3_IRQn            = 144,      /*!< TIMER3 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER4_IRQn            = 145,      /*!< TIMER4 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER5_IRQn            = 146,      /*!< TIMER5 Interrupt            */
 | 
				
			||||||
 | 
					    UART0_IRQn             = 148,      /*!< UART0  Interrupt            */
 | 
				
			||||||
 | 
					    UART1_IRQn             = 149,      /*!< UART1  Interrupt            */
 | 
				
			||||||
 | 
					    UART2_IRQn             = 150,      /*!< UART2  Interrupt            */
 | 
				
			||||||
 | 
					    UART3_IRQn             = 151,      /*!< UART3  Interrupt            */
 | 
				
			||||||
 | 
					    UART4_IRQn             = 152,      /*!< UART4  Interrupt            */
 | 
				
			||||||
 | 
					    UART5_IRQn             = 153,      /*!< UART5  Interrupt            */
 | 
				
			||||||
 | 
					    UART6_IRQn             = 154,      /*!< UART6  Interrupt            */
 | 
				
			||||||
 | 
					    UART7_IRQn             = 155,      /*!< UART7  Interrupt            */
 | 
				
			||||||
 | 
					    UART8_IRQn             = 156,      /*!< UART8  Interrupt            */
 | 
				
			||||||
 | 
					    UART9_IRQn             = 157,      /*!< UART9  Interrupt            */
 | 
				
			||||||
 | 
					    WDT0_IRQn              = 181,      /*!< WDT0  Interrupt             */
 | 
				
			||||||
 | 
					    MBOX0_CH0_B2A_IRQn     = 215,      /*!< MBOX0 CH0 B2A Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH1_B2A_IRQn     = 216,      /*!< MBOX0 CH1 B2A Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH2_B2A_IRQn     = 217,      /*!< MBOX0 CH2 B2A Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH3_B2A_IRQn     = 218,      /*!< MBOX0 CH3 B2A Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH0_A2B_IRQn     = 219,      /*!< MBOX0 CH0 A2B Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH1_A2B_IRQn     = 220,      /*!< MBOX0 CH1 A2B Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH2_A2B_IRQn     = 221,      /*!< MBOX0 CH2 A2B Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH3_A2B_IRQn     = 222,      /*!< MBOX0 CH3 A2B Interrupt     */
 | 
				
			||||||
 | 
					    TOTAL_INTERRUPTS       = (INTMUX_IRQ_START_NUM + NUM_INTERRUPTS + NUM_EXT_INTERRUPTS),
 | 
				
			||||||
 | 
					} IRQn_Type;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					typedef enum
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					/* When IPI_SGIs are used in AMP mode, you need to pay attention to whether it conflicts
 | 
				
			||||||
 | 
					 * with SMP mode. Especially in the case of Linux OS as The Master Core.
 | 
				
			||||||
 | 
					 * IPI_SGI 0~7 for non-secure and IPI_SGI 8~15 for secure.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					    IPI_SGI0               = 0,
 | 
				
			||||||
 | 
					    IPI_SGI1               = 1,
 | 
				
			||||||
 | 
					    IPI_SGI2               = 2,
 | 
				
			||||||
 | 
					    IPI_SGI3               = 3,
 | 
				
			||||||
 | 
					    IPI_SGI4               = 4,
 | 
				
			||||||
 | 
					    IPI_SGI5               = 5,
 | 
				
			||||||
 | 
					    IPI_SGI6               = 6,
 | 
				
			||||||
 | 
					    IPI_SGI7               = 7,
 | 
				
			||||||
 | 
					    IPI_SGI8               = 8,
 | 
				
			||||||
 | 
					    IPI_SGI9               = 9,
 | 
				
			||||||
 | 
					    IPI_SGI10              = 10,
 | 
				
			||||||
 | 
					    IPI_SGI11              = 11,
 | 
				
			||||||
 | 
					    IPI_SGI12              = 12,
 | 
				
			||||||
 | 
					    IPI_SGI13              = 13,
 | 
				
			||||||
 | 
					    IPI_SGI14              = 14,
 | 
				
			||||||
 | 
					    IPI_SGI15              = 15,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    CNTHP_IRQn             = 26,
 | 
				
			||||||
 | 
					    CNTV_IRQn              = 27,
 | 
				
			||||||
 | 
					    CNTPS_IRQn             = 29,
 | 
				
			||||||
 | 
					    CNTPNS_IRQn            = 30,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/******  Platform Exceptions Numbers ***************************************************/
 | 
				
			||||||
 | 
					    CAN0_IRQn              = 33,       /*!< CAN0 Interrupt              */
 | 
				
			||||||
 | 
					    CAN1_IRQn              = 34,       /*!< CAN1 Interrupt              */
 | 
				
			||||||
 | 
					    CAN2_IRQn              = 35,       /*!< CAN2 Interrupt              */
 | 
				
			||||||
 | 
					    DMAC0_ABORT_IRQn       = 45,       /*!< DMAC0 Abort Interrupt       */
 | 
				
			||||||
 | 
					    DMAC0_IRQn             = 46,       /*!< DMAC0 Interrupt             */
 | 
				
			||||||
 | 
					    DMAC1_ABORT_IRQn       = 47,       /*!< DMAC1 Abort Interrupt       */
 | 
				
			||||||
 | 
					    DMAC1_IRQn             = 48,       /*!< DMAC1 Interrupt             */
 | 
				
			||||||
 | 
					    GMAC0_IRQn             = 59,       /*!< GMAC0 Interrupt             */
 | 
				
			||||||
 | 
					    GMAC1_IRQn             = 64,       /*!< GMAC1 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO0_IRQn             = 65,       /*!< GPIO0 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO1_IRQn             = 66,       /*!< GPIO1 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO2_IRQn             = 67,       /*!< GPIO2 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO3_IRQn             = 68,       /*!< GPIO3 Interrupt             */
 | 
				
			||||||
 | 
					    GPIO4_IRQn             = 69,       /*!< GPIO4 Interrupt             */
 | 
				
			||||||
 | 
					    I2C0_IRQn              = 78,       /*!< I2C0 Interrupt              */
 | 
				
			||||||
 | 
					    I2C1_IRQn              = 79,       /*!< I2C1 Interrupt              */
 | 
				
			||||||
 | 
					    I2C2_IRQn              = 80,       /*!< I2C2 Interrupt              */
 | 
				
			||||||
 | 
					    I2C3_IRQn              = 81,       /*!< I2C3 Interrupt              */
 | 
				
			||||||
 | 
					    I2C4_IRQn              = 82,       /*!< I2C4 Interrupt              */
 | 
				
			||||||
 | 
					    I2C5_IRQn              = 83,       /*!< I2C5 Interrupt              */
 | 
				
			||||||
 | 
					    PWM_PMU_IRQn           = 114,      /*!< PWM_PMU Interrupt           */
 | 
				
			||||||
 | 
					    PWM1_IRQn              = 115,      /*!< PWM1 Interrupt              */
 | 
				
			||||||
 | 
					    PWM2_IRQn              = 116,      /*!< PWM2 Interrupt              */
 | 
				
			||||||
 | 
					    PWM3_IRQn              = 117,      /*!< PWM3 Interrupt              */
 | 
				
			||||||
 | 
					    PWM_PMU_PWR_IRQn       = 118,      /*!< PWM_PMU PWR Interrupt       */
 | 
				
			||||||
 | 
					    PWM1_PWR_IRQn          = 119,      /*!< PWM1 PWR Interrupt          */
 | 
				
			||||||
 | 
					    PWM2_PWR_IRQn          = 120,      /*!< PWM2 PWR Interrupt          */
 | 
				
			||||||
 | 
					    PWM3_PWR_IRQn          = 121,      /*!< PWM3 PWR Interrupt          */
 | 
				
			||||||
 | 
					    SARADC_IRQn            = 125,      /*!< SARADC Interrupt            */
 | 
				
			||||||
 | 
					    FSPI0_IRQn             = 133,      /*!< FSPI Interrupt              */
 | 
				
			||||||
 | 
					    SPI0_IRQn              = 135,      /*!< SPI0 Interrupt              */
 | 
				
			||||||
 | 
					    SPI1_IRQn              = 136,      /*!< SPI1 Interrupt              */
 | 
				
			||||||
 | 
					    SPI2_IRQn              = 137,      /*!< SPI2 Interrupt              */
 | 
				
			||||||
 | 
					    SPI3_IRQn              = 138,      /*!< SPI3 Interrupt              */
 | 
				
			||||||
 | 
					    TIMER0_IRQn            = 141,      /*!< TIMER0 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER1_IRQn            = 142,      /*!< TIMER1 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER2_IRQn            = 143,      /*!< TIMER2 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER3_IRQn            = 144,      /*!< TIMER3 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER4_IRQn            = 145,      /*!< TIMER4 Interrupt            */
 | 
				
			||||||
 | 
					    TIMER5_IRQn            = 146,      /*!< TIMER5 Interrupt            */
 | 
				
			||||||
 | 
					    UART0_IRQn             = 148,      /*!< UART0  Interrupt            */
 | 
				
			||||||
 | 
					    UART1_IRQn             = 149,      /*!< UART1  Interrupt            */
 | 
				
			||||||
 | 
					    UART2_IRQn             = 150,      /*!< UART2  Interrupt            */
 | 
				
			||||||
 | 
					    UART3_IRQn             = 151,      /*!< UART3  Interrupt            */
 | 
				
			||||||
 | 
					    UART4_IRQn             = 152,      /*!< UART4  Interrupt            */
 | 
				
			||||||
 | 
					    UART5_IRQn             = 153,      /*!< UART5  Interrupt            */
 | 
				
			||||||
 | 
					    UART6_IRQn             = 154,      /*!< UART6  Interrupt            */
 | 
				
			||||||
 | 
					    UART7_IRQn             = 155,      /*!< UART7  Interrupt            */
 | 
				
			||||||
 | 
					    UART8_IRQn             = 156,      /*!< UART8  Interrupt            */
 | 
				
			||||||
 | 
					    UART9_IRQn             = 157,      /*!< UART9  Interrupt            */
 | 
				
			||||||
 | 
					    WDT0_IRQn              = 181,      /*!< WDT0  Interrupt             */
 | 
				
			||||||
 | 
					    PCIE30x2_LEGACY_IRQn   = 194,      /*!< PCIe3x2_legacy Interrupt    */
 | 
				
			||||||
 | 
					    DDR_ECC_CE_IRQn        = 205,      /*!< DDR ECC correctable fault Interrupt */
 | 
				
			||||||
 | 
					    DDR_ECC_UE_IRQn        = 207,      /*!< DDR ECC uncorrectable fault Interrupt */
 | 
				
			||||||
 | 
					    MBOX0_CH0_B2A_IRQn     = 215,      /*!< MBOX0 CH0 B2A Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH1_B2A_IRQn     = 216,      /*!< MBOX0 CH1 B2A Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH2_B2A_IRQn     = 217,      /*!< MBOX0 CH2 B2A Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH3_B2A_IRQn     = 218,      /*!< MBOX0 CH3 B2A Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH0_A2B_IRQn     = 219,      /*!< MBOX0 CH0 A2B Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH1_A2B_IRQn     = 220,      /*!< MBOX0 CH1 A2B Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH2_A2B_IRQn     = 221,      /*!< MBOX0 CH2 A2B Interrupt     */
 | 
				
			||||||
 | 
					    MBOX0_CH3_A2B_IRQn     = 222,      /*!< MBOX0 CH3 A2B Interrupt     */
 | 
				
			||||||
 | 
					    NFAULT0_IRQn           = 272,      /*!< DSU L3 CACHE ECC FAULT Interrupt */
 | 
				
			||||||
 | 
					    NFAULT1_IRQn           = 273,      /*!< CPU0 L1-L2 CACHE ECC FAULT Interrupt */
 | 
				
			||||||
 | 
					    NFAULT2_IRQn           = 274,      /*!< CPU1 L1-L2 CACHE ECC FAULT Interrupt */
 | 
				
			||||||
 | 
					    NFAULT3_IRQn           = 275,      /*!< CPU2 L1-L2 CACHE ECC FAULT Interrupt */
 | 
				
			||||||
 | 
					    NFAULT4_IRQn           = 276,      /*!< CPU3 L1-L2 CACHE ECC FAULT Interrupt */
 | 
				
			||||||
 | 
					    NERR0_IRQn             = 277,      /*!< DSU L3 CACHE ECC ERROR Interrupt */
 | 
				
			||||||
 | 
					    NERR1_IRQn             = 278,      /*!< CPU0 L1-L2 CACHE ECC ERROR Interrupt */
 | 
				
			||||||
 | 
					    NERR2_IRQn             = 279,      /*!< CPU1 L1-L2 CACHE ECC ERROR Interrupt */
 | 
				
			||||||
 | 
					    NERR3_IRQn             = 280,      /*!< CPU2 L1-L2 CACHE ECC ERROR Interrupt */
 | 
				
			||||||
 | 
					    NERR4_IRQn             = 281,      /*!< CPU3 L1-L2 CACHE ECC ERROR Interrupt */
 | 
				
			||||||
 | 
					    RSVD0_IRQn             = 283,      /*!< RSVD0  Interrupt            */
 | 
				
			||||||
 | 
					    RPMSG_01_IRQn          = 285,      /*!< RPMSG 0->1 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_02_IRQn          = 286,      /*!< RPMSG 0->2 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_03_IRQn          = 287,      /*!< RPMSG 0->3 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_10_IRQn          = 288,      /*!< RPMSG 1->0 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_12_IRQn          = 289,      /*!< RPMSG 1->2 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_13_IRQn          = 290,      /*!< RPMSG 1->3 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_20_IRQn          = 291,      /*!< RPMSG 2->0 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_21_IRQn          = 292,      /*!< RPMSG 2->1 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_23_IRQn          = 293,      /*!< RPMSG 2->3 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_30_IRQn          = 294,      /*!< RPMSG 3->0 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_31_IRQn          = 295,      /*!< RPMSG 3->1 Interrupt        */
 | 
				
			||||||
 | 
					    RPMSG_32_IRQn          = 296,      /*!< RPMSG 3->2 Interrupt        */
 | 
				
			||||||
 | 
					    NUM_INTERRUPTS         = 352,
 | 
				
			||||||
 | 
					} IRQn_Type;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define RSVD_IRQn(_N)               (RSVD0_IRQn + (_N))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define AMP_CPUOFF_REQ_IRQ(cpu)     RSVD_IRQn(11 + (cpu)) /* gic irq: 294 */
 | 
				
			||||||
 | 
					#define GIC_TOUCH_REQ_IRQ(cpu)      (AMP_CPUOFF_REQ_IRQ(4) + cpu) /* gic irq: 298 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GPIO_IRQ_GROUP_DIRQ_BASE    RSVD_IRQn(37) /* gic irq: 320 */
 | 
				
			||||||
 | 
					#define GPIO_IRQ_GROUP_DIRQ_NUM     (NUM_INTERRUPTS - GPIO_IRQ_GROUP_DIRQ_BASE)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define GPIO_IRQ_GROUP_GPIO0_HWIRQ  GPIO0_IRQn
 | 
				
			||||||
 | 
					#define GPIO_IRQ_GROUP_GPION_HWIRQ  GPIO4_IRQn
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* ================================================================================ */
 | 
				
			||||||
 | 
					/* ================      Processor and Core Peripheral Section     ================ */
 | 
				
			||||||
 | 
					/* ================================================================================ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(HAL_AP_CORE) && defined(HAL_MCU_CORE)
 | 
				
			||||||
 | 
					#error "HAL_AP_CORE and HAL_MCU_CORE only one of them can be enabled"
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// #if !defined(HAL_AP_CORE) && !defined(HAL_MCU_CORE)
 | 
				
			||||||
 | 
					// #error "Please define HAL_AP_CORE or HAL_MCU_CORE on hal_conf.h"
 | 
				
			||||||
 | 
					// #endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAL_AP_CORE
 | 
				
			||||||
 | 
					#define __CORTEX_A           55U          /* Cortex-A55 Core                          */
 | 
				
			||||||
 | 
					#define __FPU_PRESENT         1U          /* FPU present                              */
 | 
				
			||||||
 | 
					#define __TIM_PRESENT         1U          /* Generic Timer                            */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CACHE_LINE_SHIFT    (6U)
 | 
				
			||||||
 | 
					#define CACHE_LINE_SIZE     (0x1U << CACHE_LINE_SHIFT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define __RISC_V
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// #ifndef __ASSEMBLY__
 | 
				
			||||||
 | 
					// #include "cmsis_compiler.h"               /* CMSIS compiler specific defines */
 | 
				
			||||||
 | 
					// #ifdef __CORTEX_A
 | 
				
			||||||
 | 
					// #include "core_ca.h"
 | 
				
			||||||
 | 
					// #endif
 | 
				
			||||||
 | 
					// #include "system_rk3568.h"
 | 
				
			||||||
 | 
					// #endif /* __ASSEMBLY__ */
 | 
				
			||||||
 | 
					#include "rk3568.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/****************************************************************************************/
 | 
				
			||||||
 | 
					/*                                                                                      */
 | 
				
			||||||
 | 
					/*                                Module Address Section                                */
 | 
				
			||||||
 | 
					/*                                                                                      */
 | 
				
			||||||
 | 
					/****************************************************************************************/
 | 
				
			||||||
 | 
					/* Memory Base */
 | 
				
			||||||
 | 
					#define PCIE3X2_DBI_BASE        0xF6000000 /* PCIe dbi base address */
 | 
				
			||||||
 | 
					#define GIC_DISTRIBUTOR_BASE    0xFD400000 /* GICD base address */
 | 
				
			||||||
 | 
					#define GIC_REDISTRIBUTOR_BASE  0xFD460000 /* GICR base address */
 | 
				
			||||||
 | 
					#define PCIE3PHY_GRF_BASE       0xFDCB8000 /* S-PHY_GRF base address */
 | 
				
			||||||
 | 
					#define PCIE3X2_APB_BASE        0xFE280000 /* PCIe apb base address */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/****************************************************************************************/
 | 
				
			||||||
 | 
					/*                                                                                      */
 | 
				
			||||||
 | 
					/*                               Register Bitmap Section                                */
 | 
				
			||||||
 | 
					/*                                                                                      */
 | 
				
			||||||
 | 
					/****************************************************************************************/
 | 
				
			||||||
 | 
					/********************************** CPU Topology ****************************************/
 | 
				
			||||||
 | 
					#define MPIDR_MT_MASK       ((1U) << 24)
 | 
				
			||||||
 | 
					#define MPIDR_AFFLVL_MASK   (0xFFU)
 | 
				
			||||||
 | 
					#define MPIDR_AFF0_SHIFT    (0U)
 | 
				
			||||||
 | 
					#define MPIDR_AFF1_SHIFT    (8U)
 | 
				
			||||||
 | 
					#define MPIDR_AFF2_SHIFT    (16U)
 | 
				
			||||||
 | 
					#define MPIDR_AFF3_SHIFT    (32U)
 | 
				
			||||||
 | 
					#define MPIDR_AFFINITY_MASK (0xFFFFFFU)
 | 
				
			||||||
 | 
					#define PLATFORM_CLUSTER0_CORE_COUNT (4)
 | 
				
			||||||
 | 
					#define PLATFORM_CLUSTER1_CORE_COUNT (0)
 | 
				
			||||||
 | 
					#define PLATFORM_CORE_COUNT PLATFORM_CLUSTER0_CORE_COUNT
 | 
				
			||||||
 | 
					#define CPU_GET_AFFINITY(cpuId, clusterId) ((cpuId) << MPIDR_AFF1_SHIFT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/********************************** CACHE ECC ****************************************/
 | 
				
			||||||
 | 
					#ifndef __ASSEMBLY__
 | 
				
			||||||
 | 
					/** @addtogroup CACHE_ECC_Exported_Definition_Group1
 | 
				
			||||||
 | 
					 *  @{
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					/** the fault value will be injected */
 | 
				
			||||||
 | 
					typedef enum {
 | 
				
			||||||
 | 
					    CACHE_ECC_INJECT_UC     = 0x80000002, /**< Uncontainable Error generation */
 | 
				
			||||||
 | 
					    CACHE_ECC_INJECT_DE_UER = 0x8000000a, /**< for l1~l2, generate a exception */
 | 
				
			||||||
 | 
					} eCACHE_ECC_InjectFault;
 | 
				
			||||||
 | 
					/** @} */
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					/******************************************CRU*******************************************/
 | 
				
			||||||
 | 
					#define PLL_INPUT_OSC_RATE (24 * 1000 * 1000)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CRU_SRST_CON_CNT    29
 | 
				
			||||||
 | 
					#define CRU_GATE_CON_CNT    35
 | 
				
			||||||
 | 
					#define CRU_CLK_DIV_CON_CNT 84
 | 
				
			||||||
 | 
					#define CRU_CLK_SEL_CON_CNT 84
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define CLK(mux, div) \
 | 
				
			||||||
 | 
					    (((mux) & 0x0F0F00FFU) | (((div) & 0xFFU) << 8) | (((div) & 0x0F0F0000U) << 4))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __ASSEMBLY__
 | 
				
			||||||
 | 
					typedef enum CLOCK_Name {
 | 
				
			||||||
 | 
					    CLK_INVALID = 0U,
 | 
				
			||||||
 | 
					    PLL_APLL,
 | 
				
			||||||
 | 
					    PLL_CPLL,
 | 
				
			||||||
 | 
					    PLL_GPLL,
 | 
				
			||||||
 | 
					    PLL_NPLL,
 | 
				
			||||||
 | 
					    PLL_VPLL,
 | 
				
			||||||
 | 
					    PLL_PPLL,
 | 
				
			||||||
 | 
					    PLL_HPLL,
 | 
				
			||||||
 | 
					    CLK_WDT,
 | 
				
			||||||
 | 
					    CLK_UART0,
 | 
				
			||||||
 | 
					    CLK_I2C        = CLK(CLK_I2C_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_PWM1       = CLK(CLK_PWM1_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_PWM2       = CLK(CLK_PWM2_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_PWM3       = CLK(CLK_PWM3_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_SPI0       = CLK(CLK_SPI0_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_SPI1       = CLK(CLK_SPI1_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_SPI2       = CLK(CLK_SPI2_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_SPI3       = CLK(CLK_SPI3_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_UART1_SRC  = CLK(CLK_UART1_SRC_SEL, CLK_UART1_SRC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART1_FRAC = CLK(0U, CLK_UART1_FRAC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART1      = CLK(SCLK_UART1_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_UART2_SRC  = CLK(CLK_UART2_SRC_SEL, CLK_UART2_SRC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART2_FRAC = CLK(0U, CLK_UART2_FRAC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART2      = CLK(SCLK_UART2_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_UART3_SRC  = CLK(CLK_UART3_SRC_SEL, CLK_UART3_SRC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART3_FRAC = CLK(0U, CLK_UART3_FRAC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART3      = CLK(SCLK_UART3_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_UART4_SRC  = CLK(CLK_UART4_SRC_SEL, CLK_UART4_SRC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART4_FRAC = CLK(0U, CLK_UART4_FRAC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART4      = CLK(SCLK_UART4_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_UART5_SRC  = CLK(CLK_UART5_SRC_SEL, CLK_UART5_SRC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART5_FRAC = CLK(0U, CLK_UART5_FRAC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART5      = CLK(SCLK_UART5_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_UART6_SRC  = CLK(CLK_UART6_SRC_SEL, CLK_UART6_SRC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART6_FRAC = CLK(0U, CLK_UART6_FRAC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART6      = CLK(SCLK_UART6_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_UART7_SRC  = CLK(CLK_UART7_SRC_SEL, CLK_UART7_SRC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART7_FRAC = CLK(0U, CLK_UART7_FRAC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART7      = CLK(SCLK_UART7_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_UART8_SRC  = CLK(CLK_UART8_SRC_SEL, CLK_UART8_SRC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART8_FRAC = CLK(0U, CLK_UART8_FRAC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART8      = CLK(SCLK_UART8_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_UART9_SRC  = CLK(CLK_UART9_SRC_SEL, CLK_UART9_SRC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART9_FRAC = CLK(0U, CLK_UART9_FRAC_DIV),
 | 
				
			||||||
 | 
					    CLK_UART9      = CLK(SCLK_UART9_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_CAN0       = CLK(CLK_CAN0_SEL, CLK_CAN0_DIV),
 | 
				
			||||||
 | 
					    CLK_CAN1       = CLK(CLK_CAN1_SEL, CLK_CAN1_DIV),
 | 
				
			||||||
 | 
					    CLK_CAN2       = CLK(CLK_CAN2_SEL, CLK_CAN2_DIV),
 | 
				
			||||||
 | 
					    CLK_TSADC_TSEN = CLK(CLK_TSADC_TSEN_SEL, CLK_TSADC_TSEN_DIV),
 | 
				
			||||||
 | 
					    CLK_TSADC      = CLK(0, CLK_TSADC_DIV),
 | 
				
			||||||
 | 
					    SCLK_SFC       = CLK(SCLK_SFC_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_MAC0_2TOP          = CLK(CLK_MAC0_2TOP_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_MAC1_2TOP          = CLK(CLK_MAC1_2TOP_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_MAC0_OUT           = CLK(CLK_MAC0_OUT_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_MAC1_OUT           = CLK(CLK_MAC1_OUT_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_GMAC0_PTP_REF      = CLK(CLK_GMAC0_PTP_REF_SEL, 0U),
 | 
				
			||||||
 | 
					    CLK_GMAC1_PTP_REF      = CLK(CLK_GMAC1_PTP_REF_SEL, 0U),
 | 
				
			||||||
 | 
					    SCLK_GMAC0             = CLK(RMII0_EXTCLK_SEL, 0U),
 | 
				
			||||||
 | 
					    SCLK_GMAC1             = CLK(RMII1_EXTCLK_SEL, 0U),
 | 
				
			||||||
 | 
					    SCLK_GMAC0_RGMII_SPEED = CLK(RGMII0_CLK_SEL, 0U),
 | 
				
			||||||
 | 
					    SCLK_GMAC1_RGMII_SPEED = CLK(RGMII1_CLK_SEL, 0U),
 | 
				
			||||||
 | 
					    SCLK_GMAC0_RMII_SPEED  = CLK(RMII0_CLK_SEL, 0U),
 | 
				
			||||||
 | 
					    SCLK_GMAC1_RMII_SPEED  = CLK(RMII1_CLK_SEL, 0U),
 | 
				
			||||||
 | 
					    SCLK_GMAC0_RX_TX       = CLK(CLK_GMAC0_RX_TX_SEL, 0U),
 | 
				
			||||||
 | 
					    SCLK_GMAC1_RX_TX       = CLK(CLK_GMAC1_RX_TX_SEL, 0U),
 | 
				
			||||||
 | 
					    ACLK_PHP               = CLK(ACLK_PHP_SEL, 0U),
 | 
				
			||||||
 | 
					    HCLK_PHP               = CLK(HCLK_PHP_SEL, 0U),
 | 
				
			||||||
 | 
					    PCLK_PHP               = CLK(0U, PCLK_PHP_DIV),
 | 
				
			||||||
 | 
					    ACLK_USB               = CLK(ACLK_USB_SEL, 0U),
 | 
				
			||||||
 | 
					    HCLK_USB               = CLK(HCLK_USB_SEL, 0U),
 | 
				
			||||||
 | 
					    PCLK_USB               = CLK(0U, PCLK_USB_DIV),
 | 
				
			||||||
 | 
					} eCLOCK_Name;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					/****************************************MBOX********************************************/
 | 
				
			||||||
 | 
					#define MBOX_CNT             2
 | 
				
			||||||
 | 
					#define MBOX_CHAN_CNT        4
 | 
				
			||||||
 | 
					/****************************************GRF*********************************************/
 | 
				
			||||||
 | 
					#define GRF_IOMUX_BIT_PER_PIN	(4)
 | 
				
			||||||
 | 
					#define GRF_DS_BIT_PER_PIN	(8)
 | 
				
			||||||
 | 
					#define GRF_PULL_BIT_PER_PIN	(2)
 | 
				
			||||||
 | 
					/****************************************GPIO********************************************/
 | 
				
			||||||
 | 
					#ifdef GPIO_VER_ID
 | 
				
			||||||
 | 
					#undef GPIO_VER_ID
 | 
				
			||||||
 | 
					#define GPIO_VER_ID             (0x01000C2BU)
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					/****************************************PMU*********************************************/
 | 
				
			||||||
 | 
					#ifndef __ASSEMBLY__
 | 
				
			||||||
 | 
					typedef enum PD_Id {
 | 
				
			||||||
 | 
					    PD_INVALID = 0U,
 | 
				
			||||||
 | 
					} ePD_Id;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					/****************************************FSPI********************************************/
 | 
				
			||||||
 | 
					#define FSPI_CHIP_CNT                            (2)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __cplusplus
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif /* __cplusplus */
 | 
				
			||||||
 | 
					#endif /* __SOC_H */
 | 
				
			||||||
		Loading…
	
		Reference in New Issue