找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 2772|回復(fù): 0
收起左側(cè)

LM3S6916硬件SPI驅(qū)動(dòng) AT45DB161D

[復(fù)制鏈接]
ID:71407 發(fā)表于 2014-12-31 22:08 | 顯示全部樓層 |閱讀模式
幾個(gè)星期之前做過(guò)用LM3S6916硬件SPI驅(qū)動(dòng)AT45DB161D的實(shí)驗(yàn),實(shí)現(xiàn)了一些簡(jiǎn)單的功能,后來(lái)因?yàn)楣こ讨袥](méi)有再用到AT45DB161D,所以沒(méi)有再繼續(xù)做下去。
代碼是在網(wǎng)上找的gxlujd(彩虹)寫(xiě)的“ATMEL的DATAFLASH操作函數(shù)庫(kù)(FOR AT45DB161D)”,只要改SPI操作方面的函數(shù)就行了。
/* Peripheral definitions for EK-LM3S6965 board */
#define SDC_SSI_BASE            SSI0_BASE
#define SDC_SSI_SYSCTL_PERIPH   SYSCTL_PERIPH_SSI0
#define SDC_GPIO_PORT_BASE      GPIO_PORTA_BASE
#define SDC_GPIO_SYSCTL_PERIPH  SYSCTL_PERIPH_GPIOA
#define SDC_SSI_CLK             GPIO_PIN_2
#define SDC_SSI_TX              GPIO_PIN_5
#define SDC_SSI_RX              GPIO_PIN_4
#define SDC_SSI_PINS            (SDC_SSI_TX | SDC_SSI_RX | SDC_SSI_CLK)
#define SDC_CS_GPIO_PORT_BASE      GPIO_PORTA_BASE
#define SDC_CS_GPIO_SYSCTL_PERIPH  SYSCTL_PERIPH_GPIOA
#define SDC_CS                     GPIO_PIN_6
#define Select_Card()           GPIOPinWrite(SDC_CS_GPIO_PORT_BASE, SDC_CS, 0)
#define Deselect_Card()         GPIOPinWrite(SDC_CS_GPIO_PORT_BASE, SDC_CS, SDC_CS)

/*--------------------------- spi_hi_speed ----------------------------------*/
#define HI 1
#define LO 0
void spi_hi_speed(unsigned char on)
{
   /* Set a SPI clock speed to desired value. */
   SSIDisable(SDC_SSI_BASE);
   if(on == HI){
      /* Max. 20 MBit used for Data Transfer. */
      SSIConfig(SDC_SSI_BASE, SSI_FRF_MOTO_MODE_0,SSI_MODE_MASTER,SysCtlClockGet() / 2, 8);
   }
   else {
      /* Max. 400 kBit used in Card Initialization. */
      SSIConfig(SDC_SSI_BASE, SSI_FRF_MOTO_MODE_0, SSI_MODE_MASTER, 400000, 8);
   }
   SSIEnable(SDC_SSI_BASE);
}
/*--------------------------- spi_send --------------------------------------*/
unsigned char spi_send(unsigned char outb)
{
   // Write and Read a byte on SPI interface.
   unsigned long inb;
   SSIDataPut(SDC_SSI_BASE, outb);
   SSIDataGet(SDC_SSI_BASE, (unsigned long *)&inb);
   return (inb);
}

//*****************************************************************************
//
// SramInit puts the SRAM device in burst mode then polls the status register
// for a valid status response. Returns True if successful.
//
//*****************************************************************************
void SPI_Init(void)
{
/* Initialize and enable the SSP Interface module. */
unsigned long i;

/* Enable the peripherals used to drive the SDC on SSI, and the CS */
SysCtlPeripheralEnable(SDC_SSI_SYSCTL_PERIPH);
SysCtlPeripheralEnable(SDC_GPIO_SYSCTL_PERIPH);
SysCtlPeripheralEnable(SDC_CS_GPIO_SYSCTL_PERIPH);

/* Configure the appropriate pins to be SSI instead of GPIO */
GPIODirModeSet(SDC_GPIO_PORT_BASE, SDC_SSI_PINS, GPIO_DIR_MODE_HW);
GPIODirModeSet(SDC_CS_GPIO_PORT_BASE, SDC_CS, GPIO_DIR_MODE_OUT);
GPIOPadConfigSet(SDC_GPIO_PORT_BASE, SDC_SSI_CLK, GPIO_STRENGTH_4MA,GPIO_PIN_TYPE_STD_WPU);
GPIOPadConfigSet(SDC_GPIO_PORT_BASE, SDC_SSI_TX | SDC_SSI_RX,GPIO_STRENGTH_4MA, GPIO_PIN_TYPE_STD_WPU);
GPIOPadConfigSet(SDC_CS_GPIO_PORT_BASE, SDC_CS,GPIO_STRENGTH_4MA, GPIO_PIN_TYPE_STD_WPU);

/* Deassert the SSI0 chip select */
GPIOPinWrite(SDC_CS_GPIO_PORT_BASE, SDC_CS, SDC_CS);

/* Configure the SSI0 port */
SSIConfig(SDC_SSI_BASE, SSI_FRF_MOTO_MODE_0, SSI_MODE_MASTER, 400000, 8);
SSIEnable(SDC_SSI_BASE);

/* Send SPI Command with card not selected at 400 KBit. */
Deselect_Card();
for (i = 0; i < 16; i++)spi_send(0xFF);
}
其他的沒(méi)有改動(dòng),完整代碼在附件中,其中包含有LCDTG12232的驅(qū)動(dòng),感謝gxlujd(彩虹)無(wú)私共享源代碼!

相關(guān)帖子

回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表