嵌入式外设瞎记

您所在的位置:网站首页 mil是啥 嵌入式外设瞎记

嵌入式外设瞎记

2023-03-23 20:44| 来源: 网络整理| 查看: 265

SPI

1.常用的就是模式0 和模式3,都是上升沿采样,只不过空闲状态一个是低电平一个是高电平 Mode0:CPOL=0,CPHA=0

Mode1:CPOL=0,CPHA=1

Mode2:CPOL=1,CPHA=0

Mode3:CPOL=1,CPHA=1

2.外设初始化 在中断使能前面

#define SPI1_ITCfg(s,f) ((s)?(R8_SPI1_INTER_EN|=f):(R8_SPI1_INTER_EN&=~f)) #define SPI1_GetITFlag(f) (R8_SPI1_INT_FLAG&f) #define SPI1_ClearITFlag(f) (R8_SPI1_INT_FLAG = f) SPI1_SlaveInit(); SPI1_DataMode(Mode0_LowBitINFront); // NVIC_INT_EN(INT_ID_SPI1); // SPI1_ITCfg(1,RB_SPI_IE_FIFO_OV|RB_SPI_IF_CNT_END|RB_SPI_IE_FIFO_HF|RB_SPI_IE_BYTE_END|RB_SPI_IE_FST_BYTE);

3.SPI 中断读取数据和while(1)读取数据

3.1中断服务函数 risc-v GCC 中中断函数除了函数体还要 void SPI1_IRQHandler(void) attribute((interrupt()));

不写就很nice,只进一次中断,一个bug

一共两种: void XXXX_IRQHandler(void) attribute((interrupt(“WCH-Interrupt-fast”))); 编译出的中断服务函数是沁恒RISCV的快速中断,该写法同时也出现在沁恒的DEMO程序中,为沁恒所特有 void XXXX_IRQHandler(void) attribute((interrupt())); GCC For RISCV的通用写法,沁恒的RISCV处理器自然也支持,但这样写无法享受沁恒的快速中断特性,但更具通用性,沁恒ch565 demo中。

参考链接:https://blog.csdn.net/lone5moon/article/details/124812880

中断服务函数实现

void SPI1_IRQHandler(void) { // printf("%02x %d %d\n",R8_SPI1_INT_FLAG,R8_SPI1_FIFO_COUNT,R32_SPI1_TOTAL_CNT); // RB_SPI_IE_CNT_END R8_SPI1_FIFO_COUNT ==0 // RB_SPI_IE_FIFO_HF R8_SPI1_FIFO_COUNT ==0 // RB_SPI_IE_FIFO_OV 8/0 // RB_SPI_IE_FST_BYTE 1 2 3 // RB_SPI_IE_BYTE_END 123 // if(SPI1_GetITFlag((RB_SPI_IE_FIFO_OV))) // { // printf(" %d \n",R8_SPI1_FIFO_COUNT); // // R8_SPI1_CTRL_MOD |= RB_SPI_FIFO_DIR; // // R16_SPI1_TOTAL_CNT = 255; // // R8_SPI1_INT_FLAG = RB_SPI_IF_CNT_END; // while( R8_SPI1_FIFO_COUNT ) // { // rt_ringbuffer_put(logrb,R8_SPI1_FIFO,1); // } // SPI1_ClearITFlag(RB_SPI_IE_FIFO_OV); SPI1_SlaveRecv(buf,255); rt_ringbuffer_put(logrb,buf,255); // } // while( 1 ) // { // if( R8_SPI1_FIFO_COUNT ) // { // rt_ringbuffer_put(logrb,R8_SPI1_FIFO,1); // } // } }

没实现,尴尬

spi nand flash GD5FQ1G

先让芯片解锁 在这里插入图片描述 先通过指令实现简单擦写读 然后再移植或者自己写块管理算法,最后对接文件系统



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3