void Bios_SPIConfig(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
SPI_InitTypeDef SPI_InitStructure;
/* ʹÄÜGPIO ʱÖÓ */
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);
/* ÅäÖà SCK, MISO ¡¢ MOSI Ϊ¸´Óù¦ÄÜ */
//GPIO_PinAFConfig(GPIOB, GPIO_PinSource3, GPIO_AF_SPI3);
//GPIO_PinAFConfig(GPIOB, GPIO_PinSource4, GPIO_AF_SPI3);
//GPIO_PinAFConfig(GPIOB, GPIO_PinSource5, GPIO_AF_SPI3);
/* ÅäÖà SCK, MISO ¡¢ MOSI Ϊ¸´Óù¦ÄÜ */
GPIO_PinAFConfig(GPIOA, GPIO_PinSource5, GPIO_AF_SPI1);
//GPIO_PinAFConfig(GPIOB, GPIO_PinSource3, GPIO_AF_SPI1);
GPIO_PinAFConfig(GPIOB, GPIO_PinSource4, GPIO_AF_SPI1);
GPIO_PinAFConfig(GPIOB, GPIO_PinSource5, GPIO_AF_SPI1);
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_DOWN;
/* ÅäÖÃPB4 --> SPI1 MISO PB5 --> SPI1 MOSI*/
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4 | GPIO_Pin_5;
GPIO_Init(GPIOB, &GPIO_InitStructure);
/* ÅäÖÃPA5 --> SPI1 SCK*/
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* ´ò¿ªSPIʱÖÓ */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE);
/* ÅäÖÃSPIÓ²¼þ²ÎÊý */
SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex; /* Êý¾Ý·½Ïò£º2ÏßÈ«Ë«¹¤ */
SPI_InitStructure.SPI_Mode = SPI_Mode_Master; /* STM32µÄSPI¹¤×÷ģʽ £ºÖ÷»úģʽ */
SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b; /* Êý¾Ý볤¶È £º 8λ */
/* SPI_CPOLºÍSPI_CPHA½áºÏʹÓþö¶¨Ê±ÖÓºÍÊý¾Ý²ÉÑùµãµÄÏàλ¹Øϵ¡¢
±¾ÀýÅäÖÃ: ×ÜÏß¿ÕÏÐÊǸߵçƽ,µÚ2¸ö±ßÑØ£¨ÉÏÉýÑزÉÑùÊý¾Ý)
*/
SPI_InitStructure.SPI_CPOL = SPI_CPOL_High; /* ʱÖÓÉÏÉýÑزÉÑùÊý¾Ý */
SPI_InitStructure.SPI_CPHA = SPI_CPHA_2Edge; /* ʱÖӵĵÚ2¸ö±ßÑزÉÑùÊý¾Ý */
SPI_InitStructure.SPI_NSS = SPI_NSS_Soft; /* Ƭѡ¿ØÖÆ·½Ê½£ºÈí¼þ¿ØÖÆ */
/* ÉèÖò¨ÌØÂÊÔ¤·ÖƵϵÊý */
SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_2;
SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB; /* Êý¾Ýλ´«Êä´ÎÐò£º¸ßλÏÈ´« */
SPI_InitStructure.SPI_CRCPolynomial = 7; /* CRC¶àÏîʽ¼Ä´æÆ÷£¬¸´Î»ºóΪ7¡£±¾Àý³Ì²»Óà */
SPI_Init(SPI1, &SPI_InitStructure);
SPI_Cmd(SPI1, DISABLE); /* ÏȽûÖ¹SPI */
SPI_Cmd(SPI1, ENABLE); /* ʹÄÜSPI */
} |