344 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			344 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
/****************************************************************************
 | 
						|
 | 
						|
Copyright(c) 2019 by Aerospace C.Power (Chongqing) Microelectronics. ALL RIGHTS RESERVED.
 | 
						|
 | 
						|
This Information is proprietary to Aerospace C.Power (Chongqing) Microelectronics and MAY NOT
 | 
						|
be copied by any method or incorporated into another program without
 | 
						|
the express written consent of Aerospace C.Power. This Information or any portion
 | 
						|
thereof remains the property of Aerospace C.Power. The Information contained herein
 | 
						|
is believed to be accurate and Aerospace C.Power assumes no responsibility or
 | 
						|
liability for its use in any way and conveys no license or title under
 | 
						|
any patent or copyright and makes no representation or warranty that this
 | 
						|
Information is free from patent or copyright infringement.
 | 
						|
 | 
						|
****************************************************************************/
 | 
						|
/* os shim includes */
 | 
						|
#include "os_types.h"
 | 
						|
#include "os_task.h"
 | 
						|
#include "os_utils.h"
 | 
						|
 | 
						|
/* common includes */
 | 
						|
#include "iot_io.h"
 | 
						|
#include "iot_bitops.h"
 | 
						|
#include "iot_pkt_api.h"
 | 
						|
#include "iot_ipc.h"
 | 
						|
#include "iot_plc_lib.h"
 | 
						|
#include "iot_dbglog_api.h"
 | 
						|
#include "iot_config.h"
 | 
						|
 | 
						|
/* driver includes */
 | 
						|
#include "iot_clock.h"
 | 
						|
#include "iot_uart.h"
 | 
						|
#include "iot_led.h"
 | 
						|
 | 
						|
/* cli includes */
 | 
						|
#include "iot_cli.h"
 | 
						|
#include "iot_uart_h.h"
 | 
						|
 | 
						|
/* debug includes*/
 | 
						|
#include "dbg_io.h"
 | 
						|
 | 
						|
#include "spi.h"
 | 
						|
#include "apb.h"
 | 
						|
#include "apb_hw.h"
 | 
						|
#include "gpio_mtx.h"
 | 
						|
 | 
						|
 extern int platform_init();
 | 
						|
 | 
						|
os_task_h test_init_handle;
 | 
						|
 | 
						|
#define debug_printf(s)
 | 
						|
 | 
						|
void print_hex(int hex)
 | 
						|
{
 | 
						|
    char hex_buf[11];
 | 
						|
    int index, data;
 | 
						|
 | 
						|
    hex_buf[0] = '0';
 | 
						|
    hex_buf[1] = 'x';
 | 
						|
    hex_buf[10] = '\0';
 | 
						|
 | 
						|
    index = 9;
 | 
						|
    while(index>1)
 | 
						|
    {
 | 
						|
        data = hex&0xFF;
 | 
						|
        hex_buf[index] = (data>9) ? (data-10+'A') : (data+'0');
 | 
						|
        hex >>= 4;
 | 
						|
        index--;
 | 
						|
    }
 | 
						|
    iot_printf(hex_buf);
 | 
						|
}
 | 
						|
 | 
						|
int spi_test_device=2; //DEVICE_SPI0_MASTER;
 | 
						|
#define SPI_READ_SIZE 256
 | 
						|
char spi_tx_buf[SPI_READ_SIZE];
 | 
						|
char spi_rx_buf[SPI_READ_SIZE];
 | 
						|
xfer_buf spi_tx, spi_rx;
 | 
						|
int do_spi_test_poll = 1;
 | 
						|
void spi_test_poll()
 | 
						|
{
 | 
						|
    int offset,i;
 | 
						|
    iot_spi_cfg_t cfg = {0};
 | 
						|
    cfg.gpio.clk = 17;
 | 
						|
    cfg.gpio.cs = 18;
 | 
						|
    cfg.gpio.miso = 19;
 | 
						|
    cfg.gpio.mosi = 20;
 | 
						|
    cfg.port = 2;
 | 
						|
    (void)iot_spi_module_init(&cfg);
 | 
						|
    /* Use default configuration */
 | 
						|
    (void)iot_spi_dev_register_detail
 | 
						|
    (spi_test_device, NULL, NULL, NULL, NULL, 0x0);
 | 
						|
 | 
						|
    spi_tx.p_nt = NULL;
 | 
						|
    spi_tx.txbuf = spi_tx_buf;
 | 
						|
    spi_tx.rxbuf = spi_rx_buf;
 | 
						|
    spi_tx.size = 10;
 | 
						|
 | 
						|
    os_mem_set(spi_tx_buf, 0x55, SPI_READ_SIZE);
 | 
						|
 | 
						|
    offset = 0;
 | 
						|
    while(1)
 | 
						|
    {
 | 
						|
        spi_tx_buf[0] = (char)offset++;
 | 
						|
 | 
						|
        (void)iot_spi_poll_transfer(spi_test_device, &spi_tx);
 | 
						|
        //offset += SPI_READ_SIZE;
 | 
						|
        iot_printf("%d\r\n",spi_tx.xfer_size);
 | 
						|
        i = 0;
 | 
						|
        while(i < spi_tx.xfer_size)
 | 
						|
        {
 | 
						|
          iot_printf("0x%x, 0x%x\r\n",spi_tx.txbuf[i],spi_tx.rxbuf[i]);
 | 
						|
          i++;
 | 
						|
        }
 | 
						|
		iot_printf("---------------------------\r\n");
 | 
						|
    }
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
static xfer_buf *int_hd;
 | 
						|
 | 
						|
void spi_test_intterupt_handler(int status)
 | 
						|
{
 | 
						|
    int cnt;
 | 
						|
 | 
						|
    if(NULL == int_hd)
 | 
						|
        return ;
 | 
						|
 | 
						|
    if(status&SPI_RXFIFO_FULL)
 | 
						|
    {
 | 
						|
        (void)iot_spi_get_rx_data_cnt(DEVICE_SPI0_MASTER, &cnt);
 | 
						|
        if(int_hd->rxbuf)
 | 
						|
        {
 | 
						|
            cnt = iot_spi_read_data(DEVICE_SPI0_MASTER, int_hd->rxbuf+int_hd->xfer_size, cnt);
 | 
						|
            int_hd->xfer_size += cnt;
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            /* Clear fifo */
 | 
						|
            (void)iot_spi_read_data(DEVICE_SPI0_MASTER, NULL, cnt);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    if(status&SPI_TXFIFO_EMPTY)
 | 
						|
    {
 | 
						|
        (void)iot_spi_get_tx_data_space_cnt(DEVICE_SPI0_MASTER, &cnt);
 | 
						|
        if(int_hd->txbuf)
 | 
						|
        {
 | 
						|
            cnt = iot_spi_write_data(DEVICE_SPI0_MASTER, int_hd->rxbuf+int_hd->xfer_size, cnt);
 | 
						|
            int_hd->xfer_size += cnt;
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            (void)iot_spi_write_data(DEVICE_SPI0_MASTER, NULL, cnt);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    if(int_hd->size == int_hd->xfer_size)
 | 
						|
        int_hd = int_hd->p_nt;
 | 
						|
}
 | 
						|
 | 
						|
void spi_test_interrupt(void)
 | 
						|
{
 | 
						|
    iot_spi_cfg_t cfg = {0};
 | 
						|
    cfg.gpio.clk = 37;
 | 
						|
    cfg.gpio.cs = 28;
 | 
						|
    cfg.gpio.miso = 40;
 | 
						|
    cfg.gpio.mosi = 39;
 | 
						|
	cfg.port = 0;
 | 
						|
    (void)iot_spi_module_init(&cfg);
 | 
						|
 | 
						|
 | 
						|
    spi_tx.p_nt = NULL;
 | 
						|
    spi_tx.txbuf = spi_tx_buf;
 | 
						|
    spi_tx.rxbuf = NULL;
 | 
						|
    spi_tx.size = 0x04;
 | 
						|
    spi_tx.xfer_size =0;
 | 
						|
 | 
						|
    spi_rx.p_nt = NULL;
 | 
						|
    spi_rx.rxbuf = spi_rx_buf;
 | 
						|
    spi_rx.txbuf = NULL;
 | 
						|
    spi_rx.size = SPI_READ_SIZE;
 | 
						|
    spi_rx.xfer_size =0;
 | 
						|
 | 
						|
    int_hd = &spi_tx;
 | 
						|
 | 
						|
    /* Use default configuration */
 | 
						|
    (void)iot_spi_dev_register_detail(spi_test_device, NULL, NULL, NULL, spi_test_intterupt_handler, \
 | 
						|
        SPI_RXFIFO_FULL|SPI_TXFIFO_EMPTY);
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
void spi_pin_config(void)
 | 
						|
{
 | 
						|
    apb_enable(APB_GMTX); //GMTX_EB_OFFSET + 32
 | 
						|
    //apb_enable(APB_GPIO);
 | 
						|
    /* UART0  */
 | 
						|
    *(int*)0x44007008 = 0x0; /* FUNCTION 1 TXD */
 | 
						|
    *(int*)0x4400700C = 0x0; /* FUNCTION 1 RXD*/
 | 
						|
    *(int*)0x44020024 = 0x1000; /* SIG9 <- core */
 | 
						|
 | 
						|
    /* SPI FLASH */
 | 
						|
    /*
 | 
						|
        GPIO 20 <-> CLK
 | 
						|
        GPIO 17 <-> CS
 | 
						|
        GPIO 18 <-> MISO
 | 
						|
        GPIO 19 <-> MOSI
 | 
						|
       */
 | 
						|
#if 1
 | 
						|
    *(int*)0x44007080 = 0x0; /* FUNCTION 1 GPIO 16 */
 | 
						|
    *(int*)0x44007084 = 0x0; /* FUNCTION 1 GPIO 17 */
 | 
						|
    *(int*)0x44007088 = 0x0; /* FUNCTION 1 GPIO 18 */
 | 
						|
    *(int*)0x4400708C = 0x0; /* FUNCTION 1 GPIO 19 */
 | 
						|
#endif
 | 
						|
    *(int*)0x44020040 = 18; /* MISO <- GPIO18 */
 | 
						|
 | 
						|
    *(int*)0x44020450 = 20; /* CLK -> GPIO20 */
 | 
						|
    *(int*)0x44020444 = 21; /* CS  -> GPIO17 */
 | 
						|
    *(int*)0x4402044C = 22; /* MOSI  -> GPIO19 */
 | 
						|
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
void dma_spi_gpio_config()
 | 
						|
{
 | 
						|
    gpio_mtx_enable();
 | 
						|
    gpio_sig_info_t info1 = {
 | 
						|
        4,
 | 
						|
        {
 | 
						|
            {IO_TYPE_OUT, 0, 10, 0xff, 20},
 | 
						|
            {IO_TYPE_OUT, 0, 11, 0xff, 21},
 | 
						|
            {IO_TYPE_OUT, 0, 15, 0xff, 22},
 | 
						|
            {IO_TYPE_IN, 0, 12, 16, 0xff}
 | 
						|
        }
 | 
						|
    };
 | 
						|
    gpio_module_pin_select(&info1);
 | 
						|
    gpio_module_sig_select(&info1, GPIO_MTX_MODE_MATRIX);
 | 
						|
}
 | 
						|
 void test_init()
 | 
						|
{
 | 
						|
#if 0
 | 
						|
    /* init common modules */
 | 
						|
    iot_bitops_init();
 | 
						|
 | 
						|
    /* init os related modules and utilities */
 | 
						|
    os_utils_init();
 | 
						|
 | 
						|
    /* init dbglog module */
 | 
						|
    iot_dbglog_init();
 | 
						|
 | 
						|
    /*init uart module*/
 | 
						|
    iot_uart_init(1);
 | 
						|
 | 
						|
    spi_pin_config();
 | 
						|
#endif
 | 
						|
    //dma_spi_gpio_config();
 | 
						|
    if(do_spi_test_poll)
 | 
						|
        spi_test_poll();
 | 
						|
    else
 | 
						|
        spi_test_interrupt();
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void iot_task_1(void *arg)
 | 
						|
{
 | 
						|
    iot_printf("Entry Task 1 ..\r\n");
 | 
						|
 | 
						|
    for(;;) {
 | 
						|
       test_init();
 | 
						|
       os_delete_task(test_init_handle);
 | 
						|
    }
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
int32_t iot_task_init()
 | 
						|
{
 | 
						|
    /* start plc lib task */
 | 
						|
    test_init_handle = os_create_task(iot_task_1, NULL, 9);
 | 
						|
 | 
						|
 | 
						|
    //create the tasks;
 | 
						|
    if(test_init_handle != NULL) {
 | 
						|
        iot_printf("Task 1 created successfully .. \r\n");
 | 
						|
    }
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 | 
						|
int32_t iot_task_start()
 | 
						|
{
 | 
						|
    //start the tasks;
 | 
						|
    os_start_kernel();
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 | 
						|
static int32_t iot_platform_init()
 | 
						|
{
 | 
						|
    /*platform intialization*/
 | 
						|
    platform_init();
 | 
						|
 | 
						|
    //resource initializations;
 | 
						|
    system_clock_init();
 | 
						|
#if 0
 | 
						|
    system_uart_init();
 | 
						|
#endif
 | 
						|
    dbg_uart_init();
 | 
						|
#if 0
 | 
						|
    dbg_uart_stage1_init();
 | 
						|
 | 
						|
    iot_led_init();
 | 
						|
#endif
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
int32_t iot_module_init(void)
 | 
						|
{
 | 
						|
    //platform intialization;
 | 
						|
    iot_platform_init();
 | 
						|
 | 
						|
    //create all the tasks;
 | 
						|
    iot_task_init();
 | 
						|
 | 
						|
    iot_printf("starting...\n");
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 | 
						|
int32_t iot_module_start(void)
 | 
						|
{
 | 
						|
    int32_t res = 0;
 | 
						|
 | 
						|
    res = iot_task_start();
 | 
						|
 | 
						|
    return res;
 | 
						|
}
 | 
						|
 | 
						|
int main(void)
 | 
						|
{
 | 
						|
   //module init;
 | 
						|
    iot_module_init();
 | 
						|
    iot_module_start();
 | 
						|
    return 0;
 | 
						|
}
 |