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
先让芯片解锁
先通过指令实现简单擦写读
然后再移植或者自己写块管理算法,最后对接文件系统