Цитата
Код
GPIOB->CRH &= ~(GPIO_CRH_CNF15 | GPIO_CRH_MODE15);
GPIOB->CRH |= GPIO_CRH_CNF15_1 | GPIO_CRH_MODE15; //mosi
GPIOB->CRH &= ~(GPIO_CRH_CNF14 | GPIO_CRH_MODE14);
GPIOB->CRH |= GPIO_CRH_CNF14_0; //miso
GPIOB->CRH &= ~(GPIO_CRH_CNF13 | GPIO_CRH_MODE13);
GPIOB->CRH |= GPIO_CRH_CNF13_1 | GPIO_CRH_MODE13; //sck
GPIOB->CRH &= ~(GPIO_CRH_CNF12 | GPIO_CRH_MODE12);
GPIOB->CRH |= GPIO_CRH_MODE12; //cs
Это для серии stm32f1xx. У меня же stm32f207.
Спасибо за советы, но у меня уже было настроено на вход как видно по моим примерам.
В итоге разобрался. Дело было в том, что ядро контроллера работает на частоте 120 МГц и порт не успевает выводить значения, которые задаешь подряд. Приходиться делать задержку.
Итоговый код программы. Может кому-то пригодиться
CODE
#include <stm32f2xx_conf.h>
#include <stdio.h>
//HSE 25 MHz
//HSI 16 MHz
// PLL configure 120 MHz signal
// PCLK1 - HSE/4 - 30 MHz(APB1); PCLK2 - HSE/2 - 60 MHz(APB2)
#define DUMMY_BYTE 0xA5
#define PIN_EEPROM_SPI_CS GPIO_Pin_4
#define PIN_TAMPER GPIO_Pin_13
#define PIN_EEPROM_MOSI GPIO_Pin_12
#define PIN_EEPROM_MISO GPIO_Pin_11
#define PIN_EEPROM_SCK GPIO_Pin_10
#define PIN_SPI_CS 0x0010
#define PIN_SCK GPIO_PinSource10
#define PIN_MISO GPIO_PinSource11
#define PIN_MOSI GPIO_PinSource12
void delay(volatile uint32_t time)
{
for (; time != 0; time --);
}
void Led_Init(void)
{
RCC -> AHB1ENR |= RCC_AHB1ENR_GPIOFEN;
GPIOF -> MODER |= GPIO_MODER_MODER6_0 |
GPIO_MODER_MODER7_0 |
GPIO_MODER_MODER8_0 ;
GPIOF -> OTYPER &= ~(GPIO_OTYPER_OT_6 |
GPIO_OTYPER_OT_7 |
GPIO_OTYPER_OT_8);
GPIOF -> OSPEEDR |= GPIO_OSPEEDER_OSPEEDR6 |
GPIO_OSPEEDER_OSPEEDR7 |
GPIO_OSPEEDER_OSPEEDR8 ;
}
//////////=================SPI===============
void SPI_INIT(void)
{
SPI_InitTypeDef SPI_InitStructure;
GPIO_InitTypeDef GPIO_InitStructure;
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOC | RCC_AHB1Periph_GPIOA, ENABLE);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_SPI3, ENABLE);
/* Deinitialize SPI3 peripheral */
SPI_I2S_DeInit(SPI3);
GPIO_PinAFConfig(GPIOC, PIN_SCK , GPIO_AF_SPI3);
GPIO_PinAFConfig(GPIOC, PIN_MOSI , GPIO_AF_SPI3);
GPIO_PinAFConfig(GPIOC, PIN_MISO , GPIO_AF_SPI3);
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_NOPULL;
// SCK: выход push-pull PC10
GPIO_InitStructure.GPIO_Pin = PIN_EEPROM_SCK;
GPIO_Init(GPIOC, &GPIO_InitStructure);
// MISO: выход push-pull PC11
GPIO_InitStructure.GPIO_Pin = PIN_EEPROM_MISO;
GPIO_Init(GPIOC, &GPIO_InitStructure);
// MOSI: выход push-pull PC12
GPIO_InitStructure.GPIO_Pin = PIN_EEPROM_MOSI;
GPIO_Init(GPIOC, &GPIO_InitStructure);
//NSS: выход push-pull - use general GPIO for CS A4
GPIO_InitStructure.GPIO_Pin = PIN_EEPROM_SPI_CS;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
GPIO_Init(GPIOA, &GPIO_InitStructure);
//SPI3
SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;
SPI_InitStructure.SPI_Mode = SPI_Mode_Master;
SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;
SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low;
SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge;
SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;
SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_256;
SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;
SPI_Init(SPI3, &SPI_InitStructure);
SPI_Cmd(SPI3, ENABLE);
}
//////////////============================================================
//////////================FOR READ_WRITE SPI=================////////////
uint8_t EEPROM_Send(uint8_t byte){
while (SPI_I2S_GetFlagStatus(SPI3, SPI_I2S_FLAG_TXE) == RESET);
SPI_I2S_SendData(SPI3, byte);
while (SPI_I2S_GetFlagStatus(SPI3, SPI_I2S_FLAG_RXNE) == RESET);
return SPI_I2S_ReceiveData(SPI3);
}
void EEPROM_SendByte(uint8_t byte){
GPIO_WriteBit(GPIOA, PIN_SPI_CS, Bit_RESET);
EEPROM_Send(byte);
GPIO_WriteBit(GPIOA, PIN_SPI_CS, Bit_SET);
delay(2000);
}
uint8_t EEPROM_Receive(void)
{
return (EEPROM_Send(DUMMY_BYTE));
}
uint8_t EEPROM_ReadStatReg(void)
{
uint8_t byte;
GPIO_WriteBit(GPIOA, PIN_SPI_CS, Bit_RESET);
EEPROM_Send(0x05);
byte=EEPROM_Receive();
GPIO_WriteBit(GPIOA, PIN_SPI_CS, Bit_SET);
delay(2000);
return (byte);
}
void EEPROM_BulkErase(void)
{
EEPROM_SendByte(0xC7);
while(EEPROM_ReadStatReg() & 1);
}
/////=========================================================
volatile static uint8_t data=0;
volatile static uint8_t RegStat=0;
//////===================MAIN
int main()
{
__enable_irq(); //Включаем прерывания
Led_Init();
SPI_INIT();
EEPROM_BulkErase();
//Write enable (WREN) Instruction Sequence
EEPROM_SendByte(0x06); //command for write sequence EEPROM
//Write to EEPROM
GPIO_WriteBit(GPIOA, PIN_SPI_CS, Bit_RESET);
EEPROM_Send(0x02); //00000010 - write command
EEPROM_Send(0x00); //address
EEPROM_Send(0x00); //address
EEPROM_Send(0x00); //address
EEPROM_Send(0xAA); //data
EEPROM_Send(0xBB); //data
EEPROM_Send(0xCC); //data
while (SPI1->SR & SPI_SR_BSY);
GPIO_WriteBit(GPIOA, PIN_SPI_CS, Bit_SET);
delay(2000);
while (SPI1->SR & SPI_SR_BSY);
while(EEPROM_ReadStatReg() & 1);
///
GPIOF->ODR |= GPIO_OTYPER_ODR_6;
//Read from EEPROM
GPIO_WriteBit(GPIOA, PIN_SPI_CS, Bit_RESET);
EEPROM_Send(0x03); //read command
EEPROM_Send(0x00); //address
EEPROM_Send(0x00); //address
EEPROM_Send(0x00); //address
data = EEPROM_Receive(); //read
data = EEPROM_Receive(); //read
data = EEPROM_Receive(); //read
data = EEPROM_Receive(); //read
data = EEPROM_Receive(); //read
GPIO_WriteBit(GPIOA, PIN_SPI_CS, Bit_SET);
delay(2000);
///
GPIOF->ODR |= GPIO_OTYPER_ODR_8;
delay(8000000);
GPIOF->ODR &= ~GPIO_OTYPER_ODR_8;
delay(8000000);
GPIOF->ODR |= GPIO_OTYPER_ODR_8;
GPIOF->ODR &= ~GPIO_OTYPER_ODR_6;
delay(8000000);
while(1){};
}
Думал, что это как то просчитанно.
А так в общем все в проге было ОК :=)
Сообщение отредактировал IgorKossak - Jun 18 2012, 17:17
Причина редактирования: форматирование (лишние табы)