Advertisement
Guest User

Master

a guest
Oct 10th, 2015
224
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 4.19 KB | None | 0 0
  1. #include "stm32f10x.h"
  2. #include "stm32f10x_conf.h"
  3.  
  4. uint16_t Reciever_SPIBuffer[25];
  5.  
  6. int main(void)
  7. {
  8.        
  9. GPIO_InitTypeDef GPIO_InitStructure;
  10. SPI_InitTypeDef SPI_InitStructure;
  11. DMA_InitTypeDef DMA_InitStructure;
  12. NVIC_InitTypeDef NVIC_InitStructure;
  13. uint16_t SPIBuffer[22];
  14.  
  15. screen_init();
  16. SystemInit();
  17. LEDS_ini();
  18. RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
  19. RCC_APB1PeriphClockCmd(RCC_APB1Periph_SPI2, ENABLE);
  20. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB | RCC_APB2Periph_AFIO, ENABLE);
  21.  
  22. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13 | GPIO_Pin_15;
  23. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  24. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  25. GPIO_Init(GPIOB, &GPIO_InitStructure);
  26.  
  27. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_14;
  28. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  29. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  30. GPIO_Init(GPIOB, &GPIO_InitStructure);
  31.  
  32. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;
  33. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  34. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  35. GPIO_Init(GPIOB, &GPIO_InitStructure);
  36.  
  37. GPIO_WriteBit(GPIOB, GPIO_Pin_12, Bit_SET);
  38.  
  39. SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_32;
  40. SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge;
  41. SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low;
  42. SPI_InitStructure.SPI_CRCPolynomial = 0;
  43. SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;
  44. SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;
  45. SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;
  46. SPI_InitStructure.SPI_Mode = SPI_Mode_Master;
  47. SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;
  48. SPI_Init(SPI2, &SPI_InitStructure);
  49.  
  50. //SPI_NSSInternalSoftwareConfig(SPI2, SPI_NSSInternalSoft_Set);
  51.  
  52. SPI_I2S_DMACmd(SPI2, SPI_I2S_DMAReq_Tx, ENABLE);
  53. SPI_I2S_DMACmd(SPI2, SPI_I2S_DMAReq_Rx, ENABLE);
  54.  
  55. SPI_Cmd(SPI2, ENABLE);
  56.  
  57. // DMA Channel 4 - SPI RX
  58. DMA_InitStructure.DMA_BufferSize = 16;
  59. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
  60. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
  61. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)Reciever_SPIBuffer;
  62. DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
  63. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
  64. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal;
  65. DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&SPI2->DR;
  66. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
  67. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
  68. DMA_InitStructure.DMA_Priority = DMA_Priority_High;
  69. DMA_Init(DMA1_Channel4, &DMA_InitStructure);
  70.  
  71. DMA_ITConfig(DMA1_Channel4, DMA_IT_TC, ENABLE);
  72.  
  73. // DMA Channel 5 - SPI TX
  74. DMA_InitStructure.DMA_BufferSize = 6;
  75. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST;
  76. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
  77. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)SPIBuffer;
  78. DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
  79. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
  80. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal;
  81. DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&SPI2->DR;
  82. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
  83. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
  84. DMA_InitStructure.DMA_Priority = DMA_Priority_High;
  85. DMA_Init(DMA1_Channel5, &DMA_InitStructure);
  86.  
  87. NVIC_InitStructure.NVIC_IRQChannel = DMA1_Channel4_IRQn;
  88. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  89. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
  90. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  91. NVIC_Init(&NVIC_InitStructure);
  92.  
  93.  
  94. DMA_Cmd(DMA1_Channel4, DISABLE);
  95. DMA_Cmd(DMA1_Channel5, DISABLE);
  96. DMA_SetCurrDataCounter(DMA1_Channel4, 16);
  97. DMA_SetCurrDataCounter(DMA1_Channel5, 6);
  98. SPIBuffer[0] = 0x0;
  99. SPIBuffer[1] = 0x1;
  100. SPIBuffer[2] = 0x2;
  101. SPIBuffer[3] = 0x3;
  102. SPIBuffer[4] = 0x4;
  103. SPIBuffer[5] = 0x5;
  104. SPIBuffer[6] = 0x6;
  105.  
  106. // Chip Select Low
  107. GPIO_WriteBit(GPIOB, GPIO_Pin_12, Bit_RESET);
  108.  
  109. DMA_Cmd(DMA1_Channel4, ENABLE);
  110. DMA_Cmd(DMA1_Channel5, ENABLE);
  111.  
  112.  
  113.  
  114. while(1);
  115. }
  116.  
  117. void spi_handleDMA1Ch4Interrupt(void){
  118.   // Chip Select High
  119.   GPIO_WriteBit(GPIOB, GPIO_Pin_12, Bit_SET);
  120.  
  121. }
  122. void DMA1_Channel4_IRQHandler(void){
  123.         spi_handleDMA1Ch4Interrupt();
  124.   DMA_ClearFlag(DMA1_FLAG_TC4);
  125.        
  126. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement