提交 4f624f16 编写于 作者: R Rbb666 提交者: guo

Add Onchip flash

上级 dd0d6a7f
......@@ -41,6 +41,9 @@ if GetDepend(['BSP_USING_ADC']):
if GetDepend('BSP_USING_RTC'):
src += ['drv_rtc.c']
if GetDepend('BSP_USING_ON_CHIP_FLASH'):
src += ['drv_flash.c']
if GetDepend(['RT_USING_WDT']):
src += ['drv_wdt.c']
......
......@@ -30,9 +30,9 @@ struct ifx_adc
static struct ifx_adc ifx_adc_obj[] =
{
#ifdef BSP_USING_ADC1
#ifdef BSP_USING_ADC1
ADC1_CONFIG,
#endif
#endif
};
static rt_err_t ifx_adc_enabled(struct rt_adc_device *device, rt_uint32_t channel, rt_bool_t enabled)
......@@ -54,6 +54,7 @@ static rt_err_t ifx_adc_enabled(struct rt_adc_device *device, rt_uint32_t channe
{
/* Initialize ADC. The ADC block which can connect to pin 10[0] is selected */
result = cyhal_adc_init(&adc_obj, VPLUS_CHANNEL_0, NULL);
if (result != RT_EOK)
{
LOG_E("ADC initialization failed. Error: %ld\n", (long unsigned int)result);
......@@ -63,6 +64,7 @@ static rt_err_t ifx_adc_enabled(struct rt_adc_device *device, rt_uint32_t channe
/* Initialize a channel 0 and configure it to scan P10_0 in single ended mode. */
result = cyhal_adc_channel_init_diff(adc_ch, &adc_obj, VPLUS_CHANNEL_0,
CYHAL_ADC_VNEG, &channel_config);
if (result != RT_EOK)
{
LOG_E("ADC single ended channel initialization failed. Error: %ld\n", (long unsigned int)result);
......@@ -71,6 +73,7 @@ static rt_err_t ifx_adc_enabled(struct rt_adc_device *device, rt_uint32_t channe
/* Update ADC configuration */
result = cyhal_adc_configure(&adc_obj, &adc_config);
if (result != RT_EOK)
{
printf("ADC configuration update failed. Error: %ld\n", (long unsigned int)result);
......
......@@ -11,7 +11,7 @@
#include "drv_common.h"
#ifdef RT_USING_SERIAL
#include "drv_uart.h"
#include "drv_uart.h"
#endif
#define DBG_TAG "drv_common"
......@@ -58,6 +58,7 @@ void _Error_Handler(char *s, int num)
{
/* User can add his own implementation to report the HAL error return state */
LOG_E("Error_Handler at file:%s num:%d", s, num);
while (1)
{
}
......@@ -74,10 +75,13 @@ void rt_hw_us_delay(rt_uint32_t us)
start = SysTick->VAL;
reload = SysTick->LOAD;
us_tick = SystemCoreClock / 1000000UL;
do {
do
{
now = SysTick->VAL;
delta = start > now ? start - now : reload + start - now;
} while(delta < us_tick * us);
}
while(delta < us_tick * us);
}
/**
......@@ -91,27 +95,27 @@ RT_WEAK void rt_hw_board_init()
rt_hw_systick_init();
/* heap initialization */
#if defined(RT_USING_HEAP)
#if defined(RT_USING_HEAP)
rt_system_heap_init((void *)HEAP_BEGIN, (void *)HEAP_END);
#endif
#endif
/* pin driver initialization is open by default */
#ifdef RT_USING_PIN
#ifdef RT_USING_PIN
rt_hw_pin_init();
#endif
#endif
/* usart driver initialization is open by default */
#ifdef RT_USING_SERIAL
#ifdef RT_USING_SERIAL
rt_hw_uart_init();
#endif
#endif
/* set the shell console output device */
#if defined(RT_USING_CONSOLE) && defined(RT_USING_DEVICE)
#if defined(RT_USING_CONSOLE) && defined(RT_USING_DEVICE)
rt_console_set_device(RT_CONSOLE_DEVICE_NAME);
#endif
#endif
/* board underlying hardware initialization */
#ifdef RT_USING_COMPONENTS_INIT
#ifdef RT_USING_COMPONENTS_INIT
rt_components_board_init();
#endif
#endif
}
/*
* Copyright (c) 2006-2022, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2022-07-26 Rbb666 first version
*/
#include <rtthread.h>
#include "drv_common.h"
#ifdef BSP_USING_ON_CHIP_FLASH
#include "drv_flash.h"
#if defined(RT_USING_FAL)
#include "fal.h"
#endif
#define DRV_DEBUG
#define LOG_TAG "drv.flash"
#include <drv_log.h>
static cyhal_flash_t flash_obj;
static cyhal_flash_block_info_t block_info;
static cyhal_flash_info_t flash_info;
int _flash_init(void)
{
cy_rslt_t err = CY_RSLT_SUCCESS;
/* Init Flash */
err = cyhal_flash_init(&flash_obj);
/* Handle Error */
if (CY_RSLT_SUCCESS != err)
{
LOG_E("\r\n Flash Init failed");
}
cyhal_flash_get_info(&flash_obj, &flash_info);
block_info = flash_info.blocks[flash_info.block_count - 1u];
return 0;
}
static rt_uint32_t get_page_32k(uint32_t addr)
{
rt_uint32_t page = 0;
page = RT_ALIGN_DOWN(addr, IFX_EFLASH_PAGE_SIZE);
return page;
}
/**
* @brief gets the page of a given address
* @param addr: address of the flash memory
* @retval the page of a given address
*/
static rt_uint32_t get_page_256k(uint32_t addr)
{
rt_uint32_t page = 0;
page = RT_ALIGN_DOWN(addr, IFX_FLASH_PAGE_SIZE);
return page;
}
int ifx_flash_read_32k(rt_uint32_t addr, rt_uint8_t *buf, rt_uint32_t size)
{
rt_uint32_t i;
if ((addr + size) > IFX_EFLASH_END_ADDRESS)
{
LOG_E("read outrange flash size! addr is (0x%p)", (void *)(addr + size));
return -RT_EINVAL;
}
for (i = 0; i < size; i++, buf++, addr++)
{
*buf = *(rt_uint8_t *) addr;
}
return size;
}
/**
* @brief read data from flash.
* @note this operation's units is word.
*
* @param addr flash address
* @param buf buffer to store read data
* @param size read bytes size
*
* @return result
*/
int ifx_flash_read_256k(rt_uint32_t addr, rt_uint8_t *buf, rt_uint32_t size)
{
rt_uint32_t i;
if ((addr + size) > IFX_FLASH_END_ADDRESS)
{
LOG_E("read outrange flash size! addr is (0x%p)", (void *)(addr + size));
return -RT_EINVAL;
}
for (i = 0; i < size; i++, buf++, addr++)
{
*buf = *(rt_uint8_t *) addr;
}
return size;
}
/**
* @brief write data to flash.
* @note this operation's units is word.
* @note this operation must after erase. @see flash_erase.
*
* @param addr flash address
* @param buf the write data buffer
* @param size write bytes size
*
* @return result
*/
int ifx_flash_write(rt_uint32_t addr, const rt_uint8_t *buf, rt_uint32_t size)
{
rt_err_t result = RT_EOK;
rt_base_t level;
cy_rslt_t err = CY_RSLT_SUCCESS;
size_t written_size = 0;
#define BSP_FEATURE_FLASH_WRITE_SIZE 512U
if (size % BSP_FEATURE_FLASH_WRITE_SIZE)
{
LOG_E("Flash Write size must be an integer multiple of %d", BSP_FEATURE_FLASH_WRITE_SIZE);
return -RT_EINVAL;
}
while (written_size < size)
{
level = rt_hw_interrupt_disable();
/* Write code flash data*/
err = cyhal_flash_write(&flash_obj, addr + written_size, (rt_uint32_t *)(buf + written_size));
rt_hw_interrupt_enable(level);
/* Error Handle */
if (CY_RSLT_SUCCESS != err)
{
LOG_E("Write API failed");
return -RT_EIO;
}
written_size += BSP_FEATURE_FLASH_WRITE_SIZE;
}
if (result != RT_EOK)
{
return result;
}
return size;
}
int ifx_flash_erase_32k(rt_uint32_t addr, rt_uint32_t size)
{
rt_err_t result = RT_EOK;
rt_uint32_t end_addr = addr + size;
rt_uint32_t page_addr = 0;
rt_base_t level;
level = rt_hw_interrupt_disable();
if ((end_addr) > IFX_EFLASH_END_ADDRESS)
{
LOG_E("erase outrange flash size! addr is (0x%p)", (void *)(addr + size));
return -RT_EINVAL;
}
while (addr < end_addr)
{
page_addr = get_page_32k(addr);
if (cyhal_flash_erase(&flash_obj, page_addr) != CY_RSLT_SUCCESS)
{
result = -RT_ERROR;
goto __exit;
}
addr += IFX_FLASH_PAGE_SIZE;
}
rt_hw_interrupt_enable(level);
__exit:
if (result != RT_EOK)
{
return result;
}
return size;
}
/**
* @brief erase data on flash .
* @note this operation is irreversible.
* @note this operation's units is different which on many chips.
*
* @param addr flash address
* @param size erase bytes size
*
* @return result
*/
int ifx_flash_erase_256k(rt_uint32_t addr, rt_uint32_t size)
{
rt_err_t result = RT_EOK;
rt_uint32_t end_addr = addr + size;
rt_uint32_t page_addr = 0;
rt_base_t level;
level = rt_hw_interrupt_disable();
if ((end_addr) > IFX_FLASH_END_ADDRESS)
{
LOG_E("erase outrange flash size! addr is (0x%p)", (void *)(addr + size));
return -RT_EINVAL;
}
while (addr < end_addr)
{
page_addr = get_page_256k(addr);
if (cyhal_flash_erase(&flash_obj, page_addr) != CY_RSLT_SUCCESS)
{
result = -RT_ERROR;
goto __exit;
}
addr += IFX_FLASH_PAGE_SIZE;
}
rt_hw_interrupt_enable(level);
__exit:
if (result != RT_EOK)
{
return result;
}
return size;
}
#if defined(RT_USING_FAL)
static int fal_flash_read_32k(long offset, rt_uint8_t *buf, size_t size);
static int fal_flash_read_256k(long offset, rt_uint8_t *buf, size_t size);
static int fal_flash_write_32k(long offset, const rt_uint8_t *buf, size_t size);
static int fal_flash_write_256k(long offset, const rt_uint8_t *buf, size_t size);
static int fal_flash_erase_32k(long offset, size_t size);
static int fal_flash_erase_256k(long offset, size_t size);
const struct fal_flash_dev ifx_onchip_flash_32k =
{
"onchip_flash_32k",
IFX_EFLASH_START_ADRESS,
IFX_EFLASH_SIZE,
IFX_EFLASH_PAGE_SIZE,
{
NULL,
fal_flash_read_32k,
fal_flash_write_32k,
fal_flash_erase_32k
}
};
const struct fal_flash_dev ifx_onchip_flash_256k =
{
"onchip_flash_256k",
IFX_FLASH_START_ADRESS,
IFX_FLASH_SIZE,
IFX_FLASH_PAGE_SIZE,
{
_flash_init,
fal_flash_read_256k,
fal_flash_write_256k,
fal_flash_erase_256k
}
};
static int fal_flash_read_32k(long offset, rt_uint8_t *buf, size_t size)
{
return ifx_flash_read_32k(ifx_onchip_flash_32k.addr + offset, buf, size);
}
static int fal_flash_read_256k(long offset, rt_uint8_t *buf, size_t size)
{
return ifx_flash_read_256k(ifx_onchip_flash_256k.addr + offset, buf, size);
}
static int fal_flash_write_32k(long offset, const rt_uint8_t *buf, size_t size)
{
return ifx_flash_write(ifx_onchip_flash_32k.addr + offset, buf, size);
}
static int fal_flash_write_256k(long offset, const rt_uint8_t *buf, size_t size)
{
return ifx_flash_write(ifx_onchip_flash_256k.addr + offset, buf, size);
}
static int fal_flash_erase_32k(long offset, size_t size)
{
return ifx_flash_erase_32k(ifx_onchip_flash_32k.addr + offset, size);
}
static int fal_flash_erase_256k(long offset, size_t size)
{
return ifx_flash_erase_256k(ifx_onchip_flash_256k.addr + offset, size);
}
#if defined(BSP_USING_ON_CHIP_FLASH)
static int rt_hw_on_chip_flash_init(void)
{
fal_init();
return RT_EOK;
}
INIT_ENV_EXPORT(rt_hw_on_chip_flash_init);
int flash64k_test(void)
{
#define TEST_OFF (ifx_onchip_flash_256k.len - 0x40000)
const struct fal_partition *param;
uint8_t write_buffer[512U] = {0};
uint8_t read_buffer[512U] = {0};
/* Set write buffer, clear read buffer */
for (uint16_t index = 0; index < 512U; index++)
{
write_buffer[index] = index;
read_buffer[index] = 0;
}
param = fal_partition_find("app");
if (param == RT_NULL)
{
LOG_E("not find partition app!");
return -1;
}
LOG_I("Erase Start...");
fal_partition_erase(param, TEST_OFF, 0x40000);
LOG_I("Erase succeeded!");
LOG_I("Write Start...");
fal_partition_write(param, TEST_OFF, write_buffer, sizeof(write_buffer));
LOG_I("Write succeeded!");
LOG_I("Read Start...");
fal_partition_read(param, TEST_OFF, read_buffer, 128U);
LOG_I("Read succeeded!");
for (int i = 0; i < 128U; i++)
{
if (read_buffer[i] != write_buffer[i])
{
LOG_E("Data verification failed!");
return -1;
}
}
LOG_I("Data verification succeeded!");
return 0;
}
MSH_CMD_EXPORT(flash64k_test, "drv flash64k test.");
int flash32k_test(void)
{
#define TEST32_OFF (ifx_onchip_flash_32k.len - 0x8000)
const struct fal_partition *param;
uint8_t write_buffer[512U] = {0};
uint8_t read_buffer[512U] = {0};
/* Set write buffer, clear read buffer */
for (uint16_t index = 0; index < 512U; index++)
{
write_buffer[index] = index;
read_buffer[index] = 0;
}
param = fal_partition_find("param");
if (param == RT_NULL)
{
LOG_E("not find partition param!");
return -1;
}
LOG_I("Erase Start...");
fal_partition_erase(param, TEST32_OFF, 0x8000);
LOG_I("Erase succeeded!");
LOG_I("Write Start...");
fal_partition_write(param, TEST32_OFF, write_buffer, sizeof(write_buffer));
LOG_I("Write succeeded!");
LOG_I("Read Start...");
fal_partition_read(param, TEST32_OFF, read_buffer, 128U);
LOG_I("Read succeeded!");
for (int i = 0; i < 128U; i++)
{
if (read_buffer[i] != write_buffer[i])
{
LOG_E("Data verification failed!");
return -1;
}
}
LOG_I("Data verification succeeded!");
return 0;
}
MSH_CMD_EXPORT(flash32k_test, "drv flash32k test.");
#endif
#endif
#endif /* BSP_USING_ON_CHIP_FLASH */
/*
* Copyright (c) 2006-2022, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2022-07-26 Rbb666 first version
*/
#ifndef __DRV_FLASH_H__
#define __DRV_FLASH_H__
#include <rtthread.h>
#include "rtdevice.h"
#include <rthw.h>
#ifdef __cplusplus
extern "C" {
#endif
int ifx_flash_read(rt_uint32_t addr, rt_uint8_t *buf, rt_uint32_t size);
int ifx_flash_write(rt_uint32_t addr, const rt_uint8_t *buf, rt_uint32_t size);
int ifx_flash_erase(rt_uint32_t addr, rt_uint32_t size);
#ifdef __cplusplus
}
#endif
#endif /* __DRV_FLASH_H__ */
......@@ -104,21 +104,25 @@ static void ifx_pin_mode(rt_device_t dev, rt_base_t pin, rt_base_t mode)
switch (mode)
{
case PIN_MODE_OUTPUT:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_OUTPUT, CYHAL_GPIO_DRIVE_STRONG, true);
break;
case PIN_MODE_INPUT:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_INPUT, CYHAL_GPIO_DRIVE_NONE, false);
break;
case PIN_MODE_INPUT_PULLUP:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_BIDIRECTIONAL, CYHAL_GPIO_DRIVE_PULLUP, true);
break;
case PIN_MODE_INPUT_PULLDOWN:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_BIDIRECTIONAL, CYHAL_GPIO_DRIVE_PULLDOWN, false);
break;
case PIN_MODE_OUTPUT_OD:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_BIDIRECTIONAL, CYHAL_GPIO_DRIVE_PULLUP, true);
break;
case PIN_MODE_OUTPUT:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_OUTPUT, CYHAL_GPIO_DRIVE_STRONG, true);
break;
case PIN_MODE_INPUT:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_INPUT, CYHAL_GPIO_DRIVE_NONE, false);
break;
case PIN_MODE_INPUT_PULLUP:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_BIDIRECTIONAL, CYHAL_GPIO_DRIVE_PULLUP, true);
break;
case PIN_MODE_INPUT_PULLDOWN:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_BIDIRECTIONAL, CYHAL_GPIO_DRIVE_PULLDOWN, false);
break;
case PIN_MODE_OUTPUT_OD:
cyhal_gpio_init(gpio_pin, CYHAL_GPIO_DIR_BIDIRECTIONAL, CYHAL_GPIO_DRIVE_PULLUP, true);
break;
}
}
......@@ -172,6 +176,7 @@ static rt_err_t ifx_pin_attach_irq(struct rt_device *device, rt_int32_t pin,
}
level = rt_hw_interrupt_disable();
if (pin_irq_handler_tab[gpio_port].pin == pin &&
pin_irq_handler_tab[gpio_port].hdr == hdr &&
pin_irq_handler_tab[gpio_port].mode == mode &&
......@@ -180,11 +185,13 @@ static rt_err_t ifx_pin_attach_irq(struct rt_device *device, rt_int32_t pin,
rt_hw_interrupt_enable(level);
return RT_EOK;
}
if (pin_irq_handler_tab[gpio_port].pin != -1)
{
rt_hw_interrupt_enable(level);
return RT_EBUSY;
}
pin_irq_handler_tab[gpio_port].pin = pin;
pin_irq_handler_tab[gpio_port].hdr = hdr;
pin_irq_handler_tab[gpio_port].mode = mode;
......@@ -211,6 +218,7 @@ static rt_err_t ifx_pin_dettach_irq(struct rt_device *device, rt_int32_t pin)
}
level = rt_hw_interrupt_disable();
if (pin_irq_handler_tab[gpio_port].pin == -1)
{
rt_hw_interrupt_enable(level);
......@@ -267,17 +275,20 @@ static rt_err_t ifx_pin_irq_enable(struct rt_device *device, rt_base_t pin,
switch (pin_irq_handler_tab[gpio_port].mode)
{
case PIN_IRQ_MODE_RISING:
pin_irq_mode = CYHAL_GPIO_IRQ_RISE;
break;
case PIN_IRQ_MODE_FALLING:
pin_irq_mode = CYHAL_GPIO_IRQ_FALL;
break;
case PIN_IRQ_MODE_RISING_FALLING:
pin_irq_mode = CYHAL_GPIO_IRQ_BOTH;
break;
default:
break;
case PIN_IRQ_MODE_RISING:
pin_irq_mode = CYHAL_GPIO_IRQ_RISE;
break;
case PIN_IRQ_MODE_FALLING:
pin_irq_mode = CYHAL_GPIO_IRQ_FALL;
break;
case PIN_IRQ_MODE_RISING_FALLING:
pin_irq_mode = CYHAL_GPIO_IRQ_BOTH;
break;
default:
break;
}
cyhal_gpio_enable_event(gpio_pin, pin_irq_mode, GPIO_INTERRUPT_PRIORITY, RT_TRUE);
......@@ -290,9 +301,9 @@ static rt_err_t ifx_pin_irq_enable(struct rt_device *device, rt_base_t pin,
Cy_GPIO_Port_Deinit(CYHAL_GET_PORTADDR(gpio_pin));
#if !defined(COMPONENT_CAT1C)
#if !defined(COMPONENT_CAT1C)
IRQn_Type irqn = (IRQn_Type)(irqmap->irqno + PORT_GET(irqmap->port));
#endif
#endif
_cyhal_irq_disable(irqn);
rt_hw_interrupt_enable(level);
......
......@@ -13,15 +13,15 @@
*/
#ifndef LOG_TAG
#define DBG_TAG "drv"
#define DBG_TAG "drv"
#else
#define DBG_TAG LOG_TAG
#define DBG_TAG LOG_TAG
#endif /* LOG_TAG */
#ifdef DRV_DEBUG
#define DBG_LVL DBG_LOG
#define DBG_LVL DBG_LOG
#else
#define DBG_LVL DBG_INFO
#define DBG_LVL DBG_INFO
#endif /* DRV_DEBUG */
#include <rtdbg.h>
......@@ -31,47 +31,47 @@ struct ifx_pwm
enum
{
#ifdef BSP_USING_PWM0
#ifdef BSP_USING_PWM0
PWM0_INDEX,
#endif
#endif
};
static struct ifx_pwm ifx_pwm_obj[] =
{
#ifdef BSP_USING_PWM0
#ifdef BSP_USING_PWM0
PWM0_CONFIG,
#endif
#endif
};
static void pwm_get_pin_number(void)
{
#ifdef BSP_USING_PWM0_CH7
#ifdef BSP_USING_PWM0_PORT2
#ifdef BSP_USING_PWM0_CH7
#ifdef BSP_USING_PWM0_PORT2
ifx_pwm_obj[PWM0_INDEX].gpio = GET_PIN(2, 2);
#endif
#ifdef BSP_USING_PWM0_PORT5
#endif
#ifdef BSP_USING_PWM0_PORT5
ifx_pwm_obj[PWM0_INDEX].gpio = GET_PIN(5, 6);
#endif
#ifdef BSP_USING_PWM0_PORT7
#endif
#ifdef BSP_USING_PWM0_PORT7
ifx_pwm_obj[PWM0_INDEX].gpio = GET_PIN(7, 7);
#endif
#ifdef BSP_USING_PWM0_PORT9
#endif
#ifdef BSP_USING_PWM0_PORT9
ifx_pwm_obj[PWM0_INDEX].gpio = GET_PIN(9, 4);
#endif
#ifdef BSP_USING_PWM0_PORT10
#endif
#ifdef BSP_USING_PWM0_PORT10
ifx_pwm_obj[PWM0_INDEX].gpio = GET_PIN(10, 2);
#endif
#ifdef BSP_USING_PWM0_PORT12
#endif
#ifdef BSP_USING_PWM0_PORT12
ifx_pwm_obj[PWM0_INDEX].gpio = GET_PIN(12, 6);
#endif
#endif
#endif
#endif
}
static void pwm_get_channel(void)
{
#ifdef BSP_USING_PWM0_CH7
#ifdef BSP_USING_PWM0_CH7
ifx_pwm_obj[PWM0_INDEX].channel = 7;
#endif
#endif
}
static rt_err_t drv_pwm_enable(cyhal_pwm_t *htim, struct rt_pwm_configuration *configuration, rt_bool_t enable)
......@@ -136,20 +136,26 @@ static rt_err_t drv_pwm_control(struct rt_device_pwm *device, int cmd, void *arg
switch (cmd)
{
case PWMN_CMD_ENABLE:
configuration->complementary = RT_TRUE;
case PWM_CMD_ENABLE:
return drv_pwm_enable(htim, configuration, RT_TRUE);
case PWMN_CMD_DISABLE:
configuration->complementary = RT_FALSE;
case PWM_CMD_DISABLE:
return drv_pwm_enable(htim, configuration, RT_FALSE);
case PWM_CMD_SET:
return drv_pwm_set(htim, configuration);
case PWM_CMD_GET:
return drv_pwm_get(htim, configuration);
default:
return RT_EINVAL;
case PWMN_CMD_ENABLE:
configuration->complementary = RT_TRUE;
case PWM_CMD_ENABLE:
return drv_pwm_enable(htim, configuration, RT_TRUE);
case PWMN_CMD_DISABLE:
configuration->complementary = RT_FALSE;
case PWM_CMD_DISABLE:
return drv_pwm_enable(htim, configuration, RT_FALSE);
case PWM_CMD_SET:
return drv_pwm_set(htim, configuration);
case PWM_CMD_GET:
return drv_pwm_get(htim, configuration);
default:
return RT_EINVAL;
}
}
......@@ -232,6 +238,7 @@ static int pwm_sample(int argc, char *argv[])
pulse = 0;
pwm_dev = (struct rt_device_pwm *)rt_device_find(PWM_DEV_NAME);
if (pwm_dev == RT_NULL)
{
rt_kprintf("pwm sample run failed! can't find %s device!\n", PWM_DEV_NAME);
......@@ -253,10 +260,12 @@ static int pwm_sample(int argc, char *argv[])
{
pulse -= 5000;
}
if (pulse >= period)
{
dir = 0;
}
if (0 == pulse)
{
dir = 1;
......
......@@ -24,9 +24,9 @@ extern "C" {
#ifndef PWM0_CONFIG
#define PWM0_CONFIG \
{ \
.name = "pwm0", \
.channel = 0, \
.gpio = 0, \
.name = "pwm0", \
.channel = 0, \
.gpio = 0, \
}
#endif /* PWM0_CONFIG */
#endif /* BSP_USING_PWM0 */
......
......@@ -28,6 +28,7 @@ static int get_day_of_week(int day, int month, int year)
int ret;
int k = 0;
int j = 0;
if (month < CY_RTC_MARCH)
{
month += CY_RTC_MONTHS_PER_YEAR;
......@@ -48,6 +49,7 @@ static rt_err_t set_rtc_time_stamp(time_t time_stamp)
struct tm new_time = {0};
gmtime_r(&time_stamp, &tm);
if (tm.tm_year < 100)
{
return -RT_ERROR;
......@@ -120,6 +122,7 @@ static rt_err_t _rtc_set_secs(time_t *sec)
{
result = -RT_ERROR;
}
LOG_D("RTC: set rtc_time %d", *sec);
return result;
......
......@@ -24,9 +24,9 @@
static const struct ifx_soft_i2c_config soft_i2c_config[] =
{
#ifdef BSP_USING_I2C1
#ifdef BSP_USING_I2C1
I2C1_BUS_CONFIG,
#endif
#endif
};
static struct ifx_i2c i2c_obj[sizeof(soft_i2c_config) / sizeof(soft_i2c_config[0])];
......@@ -56,6 +56,7 @@ static void ifx_i2c_gpio_init(struct ifx_i2c *i2c)
static void ifx_set_sda(void *data, rt_int32_t state)
{
struct ifx_soft_i2c_config *cfg = (struct ifx_soft_i2c_config *)data;
if (state)
{
rt_pin_write(cfg->sda, PIN_HIGH);
......@@ -75,6 +76,7 @@ static void ifx_set_sda(void *data, rt_int32_t state)
static void ifx_set_scl(void *data, rt_int32_t state)
{
struct ifx_soft_i2c_config *cfg = (struct ifx_soft_i2c_config *)data;
if (state)
{
rt_pin_write(cfg->scl, PIN_HIGH);
......@@ -140,6 +142,7 @@ static rt_err_t ifx_i2c_bus_unlock(const struct ifx_soft_i2c_config *cfg)
rt_hw_us_delay(100);
}
}
if (PIN_LOW == rt_pin_read(cfg->sda))
{
return -RT_ERROR;
......
......@@ -32,7 +32,7 @@ struct ifx_sw_spi_cs
static struct ifx_spi spi_bus_obj[] =
{
#ifdef BSP_USING_SPI3
#ifdef BSP_USING_SPI3
{
.bus_name = "spi3",
.spi_bus = &spi_bus3,
......@@ -40,7 +40,7 @@ static struct ifx_spi spi_bus_obj[] =
.miso_pin = GET_PIN(6, 1),
.mosi_pin = GET_PIN(6, 0),
},
#endif
#endif
};
/* private rt-thread spi ops function */
......@@ -100,18 +100,21 @@ static rt_err_t spi_configure(struct rt_spi_device *device,
/* MSB or LSB */
switch (configuration->mode & RT_SPI_MODE_3)
{
case RT_SPI_MODE_0:
spi_device->spi_obj->mode = CYHAL_SPI_MODE_00_MSB;
break;
case RT_SPI_MODE_1:
spi_device->spi_obj->mode = CYHAL_SPI_MODE_01_MSB;
break;
case RT_SPI_MODE_2:
spi_device->spi_obj->mode = CYHAL_SPI_MODE_10_MSB;
break;
case RT_SPI_MODE_3:
spi_device->spi_obj->mode = CYHAL_SPI_MODE_11_MSB;
break;
case RT_SPI_MODE_0:
spi_device->spi_obj->mode = CYHAL_SPI_MODE_00_MSB;
break;
case RT_SPI_MODE_1:
spi_device->spi_obj->mode = CYHAL_SPI_MODE_01_MSB;
break;
case RT_SPI_MODE_2:
spi_device->spi_obj->mode = CYHAL_SPI_MODE_10_MSB;
break;
case RT_SPI_MODE_3:
spi_device->spi_obj->mode = CYHAL_SPI_MODE_11_MSB;
break;
}
ifx_spi_init(spi_device);
......
......@@ -17,46 +17,46 @@
enum
{
#ifdef BSP_USING_UART0
#ifdef BSP_USING_UART0
UART0_INDEX,
#endif
#ifdef BSP_USING_UART1
#endif
#ifdef BSP_USING_UART1
UART1_INDEX,
#endif
#ifdef BSP_USING_UART2
#endif
#ifdef BSP_USING_UART2
UART2_INDEX,
#endif
#ifdef BSP_USING_UART3
#endif
#ifdef BSP_USING_UART3
UART3_INDEX,
#endif
#ifdef BSP_USING_UART4
#endif
#ifdef BSP_USING_UART4
UART4_INDEX,
#endif
#ifdef BSP_USING_UART5
#endif
#ifdef BSP_USING_UART5
UART5_INDEX,
#endif
#endif
};
static struct ifx_uart_config uart_config[] =
{
#ifdef BSP_USING_UART0
#ifdef BSP_USING_UART0
UART0_CONFIG,
#endif
#ifdef BSP_USING_UART1
#endif
#ifdef BSP_USING_UART1
UART1_CONFIG,
#endif
#ifdef BSP_USING_UART2
#endif
#ifdef BSP_USING_UART2
UART2_CONFIG,
#endif
#ifdef BSP_USING_UART3
#endif
#ifdef BSP_USING_UART3
UART3_CONFIG,
#endif
#ifdef BSP_USING_UART4
#endif
#ifdef BSP_USING_UART4
UART4_CONFIG,
#endif
#ifdef BSP_USING_UART5
#endif
#ifdef BSP_USING_UART5
UART5_CONFIG,
#endif
#endif
};
static struct ifx_uart uart_obj[sizeof(uart_config) / sizeof(uart_config[0])] = {0};
......@@ -196,20 +196,20 @@ static rt_err_t ifx_control(struct rt_serial_device *serial, int cmd, void *arg)
switch (cmd)
{
case RT_DEVICE_CTRL_CLR_INT:
case RT_DEVICE_CTRL_CLR_INT:
break;
break;
case RT_DEVICE_CTRL_SET_INT:
/* Unmasking only the RX fifo not empty interrupt bit */
uart->config->usart_x->INTR_RX_MASK = SCB_INTR_RX_MASK_NOT_EMPTY_Msk;
case RT_DEVICE_CTRL_SET_INT:
/* Unmasking only the RX fifo not empty interrupt bit */
uart->config->usart_x->INTR_RX_MASK = SCB_INTR_RX_MASK_NOT_EMPTY_Msk;
/* Interrupt Settings for UART */
Cy_SysInt_Init(uart->config->UART_SCB_IRQ_cfg, uart->config->userIsr);
/* Interrupt Settings for UART */
Cy_SysInt_Init(uart->config->UART_SCB_IRQ_cfg, uart->config->userIsr);
/* Enable the interrupt */
NVIC_EnableIRQ(uart->config->intrSrc);
break;
/* Enable the interrupt */
NVIC_EnableIRQ(uart->config->intrSrc);
break;
}
return (RT_EOK);
......@@ -227,6 +227,7 @@ static int ifx_uarths_putc(struct rt_serial_device *serial, char c)
return CYHAL_SYSPM_RSLT_ERR_PM_PENDING;
uint32_t count = 0;
while (count == 0)
{
count = Cy_SCB_UART_Put(uart->config->usart_x, c);
......@@ -245,6 +246,7 @@ static int ifx_uarths_getc(struct rt_serial_device *serial)
RT_ASSERT(uart != RT_NULL);
ch = -1;
if (RT_EOK == cyhal_uart_getc(uart->config->uart_obj, (uint8_t *)&read_data, 1))
{
ch = read_data & 0xff;
......
......@@ -39,41 +39,49 @@ static rt_err_t wdt_control(rt_watchdog_t *wdt_device, int cmd, void *arg)
cfg = wdt_device->parent.user_data;
rt_uint32_t timeout_ms = 0;
switch (cmd)
{
/* feed the watchdog */
case RT_DEVICE_CTRL_WDT_KEEPALIVE:
cyhal_wdt_kick(cfg->WDTx);
/* feed the watchdog */
case RT_DEVICE_CTRL_WDT_KEEPALIVE:
cyhal_wdt_kick(cfg->WDTx);
break;
/* set watchdog timeout */
case RT_DEVICE_CTRL_WDT_SET_TIMEOUT:
{
timeout_ms = *((rt_uint32_t *)arg) * 1000;
rt_uint32_t max_timeout_ms = cyhal_wdt_get_max_timeout_ms();
if (timeout_ms >= max_timeout_ms)
timeout_ms = max_timeout_ms;
/* Initialize the WDT */
int result = cyhal_wdt_init(cfg->WDTx, (rt_uint32_t)timeout_ms);
/* WDT initialization failed. Stop program execution */
RT_ASSERT(result != RT_ERROR);
}
break;
/* set watchdog timeout */
case RT_DEVICE_CTRL_WDT_SET_TIMEOUT:
{
timeout_ms = *((rt_uint32_t *)arg) * 1000;
rt_uint32_t max_timeout_ms = cyhal_wdt_get_max_timeout_ms();
if (timeout_ms >= max_timeout_ms)
timeout_ms = max_timeout_ms;
case RT_DEVICE_CTRL_WDT_GET_TIMEOUT:
timeout_ms = cyhal_wdt_get_timeout_ms(cfg->WDTx);
*(rt_uint32_t *)arg = timeout_ms / 1000;
break;
/* Initialize the WDT */
int result = cyhal_wdt_init(cfg->WDTx, (rt_uint32_t)timeout_ms);
/* WDT initialization failed. Stop program execution */
RT_ASSERT(result != RT_ERROR);
}
break;
case RT_DEVICE_CTRL_WDT_GET_TIMEOUT:
timeout_ms = cyhal_wdt_get_timeout_ms(cfg->WDTx);
*(rt_uint32_t *)arg = timeout_ms / 1000;
break;
case RT_DEVICE_CTRL_WDT_START:
cyhal_wdt_start(cfg->WDTx);
break;
case RT_DEVICE_CTRL_WDT_STOP:
cyhal_wdt_stop(cfg->WDTx);
break;
default:
LOG_W("This command is not supported.");
return -RT_ERROR;
case RT_DEVICE_CTRL_WDT_START:
cyhal_wdt_start(cfg->WDTx);
break;
case RT_DEVICE_CTRL_WDT_STOP:
cyhal_wdt_stop(cfg->WDTx);
break;
default:
LOG_W("This command is not supported.");
return -RT_ERROR;
}
return RT_EOK;
}
......@@ -93,6 +101,7 @@ int rt_hw_wdt_init(void)
LOG_E("wdt device register failed.");
return -RT_ERROR;
}
LOG_D("wdt device register success.");
return RT_EOK;
}
......
......@@ -99,6 +99,10 @@ if GetDepend('BSP_USING_RTC'):
src += ['mtb-pdl-cat1/drivers/source/cy_rtc.c']
src += ['mtb-hal-cat1/source/cyhal_rtc.c']
if GetDepend('BSP_USING_ON_CHIP_FLASH'):
src += ['mtb-pdl-cat1/drivers/source/cy_flash.c']
src += ['mtb-hal-cat1/source/cyhal_flash.c']
if GetDepend(['RT_USING_WDT']):
src += ['mtb-pdl-cat1/drivers/source/cy_wdt.c']
src += ['mtb-hal-cat1/source/cyhal_wdt.c']
......
......@@ -213,6 +213,10 @@ menu "On-chip Peripheral Drivers"
endchoice
endif
config BSP_USING_ON_CHIP_FLASH
bool "Enable on-chip FLASH"
default n
config BSP_USING_WDT
bool "Enable Watchdog Timer"
select RT_USING_WDT
......
......@@ -20,7 +20,7 @@ if GetDepend(['BSP_USING_RW007']):
src += Glob('ports/drv_rw007.c')
path = [cwd]
path += [cwd + '/port']
path += [cwd + '/ports']
startup_path_prefix = SDK_LIB
......
......@@ -6,6 +6,7 @@
* Change Logs:
* Date Author Notes
* 2022-06-29 Rbb666 first version
* 2022-07-26 Rbb666 Add Flash Config
*/
#ifndef __BOARD_H__
......@@ -20,8 +21,21 @@
#include "cy_pdl.h"
#include "cy_retarget_io.h"
#define IFX_SRAM_SIZE 1014
#define IFX_SRAM_END (0x08002000 + IFX_SRAM_SIZE * 1024)
/*FLASH CONFIG*/
#define IFX_FLASH_START_ADRESS ((uint32_t)0x10000000)
#define IFX_FLASH_PAGE_SIZE (256 * 1024)
#define IFX_FLASH_SIZE (2 * 1024 * 1024)
#define IFX_FLASH_END_ADDRESS ((uint32_t)(IFX_FLASH_START_ADRESS + IFX_FLASH_SIZE))
/*EFLASH CONFIG*/
#define IFX_EFLASH_START_ADRESS ((uint32_t)0x14000000)
#define IFX_EFLASH_PAGE_SIZE (32 * 1024)
#define IFX_EFLASH_SIZE (32 * 1024)
#define IFX_EFLASH_END_ADDRESS ((uint32_t)(IFX_EFLASH_START_ADRESS + IFX_EFLASH_SIZE))
/*SRAM CONFIG*/
#define IFX_SRAM_SIZE (1014)
#define IFX_SRAM_END (0x08002000 + IFX_SRAM_SIZE * 1024)
#ifdef __ARMCC_VERSION
extern int Image$$RW_IRAM1$$ZI$$Limit;
......
/*
* Copyright (c) 2006-2022, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2022-07-27 Rbb666 first version
*/
#ifndef _FAL_CFG_H_
#define _FAL_CFG_H_
#include <rtthread.h>
#include <board.h>
extern const struct fal_flash_dev ifx_onchip_flash_32k;
extern const struct fal_flash_dev ifx_onchip_flash_256k;
/* flash device table */
#define FAL_FLASH_DEV_TABLE \
{ \
&ifx_onchip_flash_32k, \
&ifx_onchip_flash_256k, \
}
/* ====================== Partition Configuration ========================== */
#ifdef FAL_PART_HAS_TABLE_CFG
/* partition table */
#define FAL_PART_TABLE \
{ \
{FAL_PART_MAGIC_WROD, "param", "onchip_flash_32k", 0, IFX_EFLASH_SIZE, 0}, \
{FAL_PART_MAGIC_WROD, "app", "onchip_flash_256k", 0, IFX_FLASH_SIZE, 0}, \
}
#endif /* FAL_PART_HAS_TABLE_CFG */
#endif /* _FAL_CFG_H_ */
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册