ATMEGA8A + SPI内存奇怪的行为

时间:2017-08-26 10:31:34

标签: arduino avr atmega atmel eeprom

我已经购买了SPI内存MX25L8006EPI,现在我尝试将其连接到ATMEGA8A进行测试。原理图非常简单,并且不会通过互联网改变其他原因:

enter image description here

ATMEGA8A工作于8Mz内部振荡器,3.3V。保险丝为HIGH:0xD1,LOW:0xE4。

我使用Atmel Studio 7进行编码,使用AVRISP mkII对uC进行编程。 由于EEPROM需要3.3V,因此您可以在方案中看到使用LM317连接的5V 700mA电源模块。我不认为这很重要但无论如何......

代码也非常简单,我从互联网的某个页面部分复制了代码:

#define SLAVESELECT (PORTB &= ~(1<<PORTB2))
#define SLAVEDESELECT (PORTB |= (1<<PORTB2))

#define WREN  6
#define WRDI  4
#define RDSR  5
#define WRSR  1
#define READ  3
#define WRITE 2
#define RDID 0x9F

#define byte unsigned char

void SPI_Init()
{
    DDRB = (1<<PORTB2)|(1<<PORTB3)|(1<<PORTB5);
    SLAVEDESELECT;
    //SPSR |= (1<<SPI2X);
    SPCR |= (1<<SPE)|(1<<MSTR)|(1 << SPR1);
    _delay_ms(10);
}

byte SPI_Transfer(volatile byte data)
{
    SPDR = data;
    while (!(SPSR & (1<<SPIF)));
    return SPDR;
}

void Get_Identification(byte data[3])
{
    SLAVESELECT;
    SPI_Transfer(RDID);
    data[0] = SPI_Transfer(0xFF);
    data[1] = SPI_Transfer(0xFF);
    data[2] = SPI_Transfer(0xFF);
    SLAVEDESELECT;
}

byte GetStatus()
{
    byte status;
    SLAVESELECT;
    SPI_Transfer(RDSR);
    status = SPI_Transfer(0xFF);
    SLAVEDESELECT;
    return status;
}

void SetWriteEnable(short ebable)
{
    SLAVESELECT;
    SPI_Transfer((ebable != 0) ? WREN : WRDI);
    SLAVEDESELECT;
}

void SetStatus(byte status)
{
    SetWriteEnable(1);
    SLAVESELECT;
    SPI_Transfer(WRSR);
    SPI_Transfer(status);
    SLAVEDESELECT;
    _delay_ms(100);
}

int main(void)
{
    SPI_Init();
    byte status = 0x1C;
    DEBUG_PRINT("\r\nSet status:%d\r\n",status);
    SetStatus(status);
    status = GetStatus();
    DEBUG_PRINT("\r\nGet status:%d\r\n",status);
    byte buffer[3];
    Get_Identification(buffer);
    DEBUG_PRINT("Byte0:%x\r\n", buffer[0]);
    DEBUG_PRINT("Byte1:%x\r\n", buffer[1]);
    DEBUG_PRINT("Byte2:%x\r\n", buffer[2]);

    while (1) 
    {       
    }
}

DEBUG_PRINT是我通过USART发送格式化字符串的功能。我用它打印出调试信息。

一切看起来都不错,但是当我跑步时,我会得到一些奇怪的行为。输出是:

Set status:28
Get status:24
Byte0:80
Byte1:0
Byte2:10

首先,我使用WRSR操作码设置状态寄存器。它应该设置为00011100但是当我使用RDSR操作码读取状态时,我得到00011000。

好的,也许状态寄存器有问题。然后我尝试使用RDID操作码读取ID寄存器。它应该返回3个字节​​ - 0xC2 0x20 0x14。但是我得到了0x80 0x0 0x10。

如果我没有答案或者全部为0x00或0xFF,那将是可以理解的。但在这里我读了一些答案,答案是完全错误的问题。更有趣的是,如果我使用至少相同的代码将EEPROM连接到Arduino,它可以正常工作。

我觉得问题很小。它看起来可能是某些数据顺序错误或传输速度或类似的东西,但我无法让它工作。

1 个答案:

答案 0 :(得分:0)

根据这个datasheet,当BP2:0设置为5,6或7时,所有块都受到保护。也许当你将它设置为7时,内存只将它设置为6,因为它没有没有区别。