Norflash型号为sst39vf32

#ifndef __NORFLASH_H_

#define __NORFLASH_H_

#include "common.h"

#include "delay.h"

#include "debugserial.h"

#define NOR_FLASH_BASE      0x80000000

#define NOR_FLASH_SIZE      0x00100000

#define GET_ADDR(addr)  (volatile uint16_t *)(NOR_FLASH_BASE | (addr<<1))

#define SECTOR_SIZE     0x800   /* Must be 2048 words for 39VF160 */

#define BLOCK_SIZE      0x8000  /* Must be 32K words for 39VF160  */

#define SST_ID          0xBF    /* SST Manufacturer's ID code   */

#define SST_39VF160     0x235D  /* SST 39VF160 device code      */

#define PROGRAM_TIMEOUT 0x00008000

//norflash 初始化必须在sram初始化之前

void norflash_init(void);

void norflash_erase(void);

u32 norflash_check_id(void);

u32 norflash_write_word(u32 add, u16 data);

u32 norflash_toggle_bit_check(u32 addr,u16 data);

#endif

#include "norflash.h"

static void norflash_io_init(void)

{

//a0-a22

/* init EMC_A1 */

LPC_IOCON->P4_1 = 0x21;

/* init EMC_A2 */

LPC_IOCON->P4_2 = 0x21;

/* init EMC_A3 */

LPC_IOCON->P4_3 = 0x21;

/* init EMC_A4 */

LPC_IOCON->P4_4 = 0x21;

/* init EMC_A5 */

LPC_IOCON->P4_5 = 0x21;

/* init EMC_A6 */

LPC_IOCON->P4_6 = 0x21;

/* init EMC_A7 */

LPC_IOCON->P4_7 = 0x21;

/* init EMC_A8 */

LPC_IOCON->P4_8 = 0x21;

/* init EMC_A9 */

LPC_IOCON->P4_9 = 0x21;

/* init EMC_A10 */

LPC_IOCON->P4_10 = 0x21;

/* init EMC_A11 */

LPC_IOCON->P4_11 = 0x21;

/* init EMC_A12 */

LPC_IOCON->P4_12 = 0x21;

/* init EMC_A13 */

LPC_IOCON->P4_13 = 0x21;

/* init EMC_A14 */

LPC_IOCON->P4_14 = 0x21;

/* init EMC_A15 */

LPC_IOCON->P4_15 = 0x21;

/* init EMC_A16 */

LPC_IOCON->P4_16 = 0x21;

/* init EMC_A17 */

LPC_IOCON->P4_17 = 0x21;

/* init EMC_A18 */

LPC_IOCON->P4_18 = 0x21;

/* init EMC_A19 */

LPC_IOCON->P4_19 = 0x21;

/* init EMC_A20 */

LPC_IOCON->P4_20 = 0x21;

/* init EMC_A21 */

LPC_IOCON->P4_21 = 0x21;

/* init EMC_A22 */

LPC_IOCON->P4_22 = 0x21;

//d0-d15

/* init EMC_D0 */

LPC_IOCON->P3_0 = 0x21;

/* init EMC_D1 */

LPC_IOCON->P3_1 = 0x21;

/* init EMC_D2 */

LPC_IOCON->P3_2 = 0x21;

/* init EMC_D3 */

LPC_IOCON->P3_3 = 0x21;

/* init EMC_D4 */

LPC_IOCON->P3_4 = 0x21;

/* init EMC_D5 */

LPC_IOCON->P3_5 = 0x21;

/* init EMC_D6 */

LPC_IOCON->P3_6 = 0x21;

/* init EMC_D7 */

LPC_IOCON->P3_7 = 0x21;

/* init EMC_D8 */

LPC_IOCON->P3_8 = 0x21;

/* init EMC_D9 */

LPC_IOCON->P3_9 = 0x21;

/* init EMC_D10 */

LPC_IOCON->P3_10 = 0x21;

/* init EMC_D11 */

LPC_IOCON->P3_11 = 0x21;

/* init EMC_D12 */

LPC_IOCON->P3_12 = 0x21;

/* init EMC_D13 */

LPC_IOCON->P3_13 = 0x21;

/* init EMC_D14 */

LPC_IOCON->P3_14 = 0x21;

/* init EMC_D15 */

LPC_IOCON->P3_15 = 0x21;

/* init EMC_WE */

LPC_IOCON->P4_25 = 0x21;

/* init EMC_oe */

LPC_IOCON->P4_24 = 0x21;

/* init EMC_cs0 */

LPC_IOCON->P4_30 = 0x21;

}

void norflash_init(void)

{

LPC_SC->SCS |= (1<<0);//emc地址不移位

//打开emc时钟与端口时钟

LPC_SC->PCONP |= (1<<15)|(1<<11);//打开时钟

LPC_SC->EMCDLYCTL = 0x00001010;//延时时间初始化

LPC_EMC->Control  = 0x00000001;//emc使能

LPC_EMC->Config  = 0x00000000;//emc配置清零,小端模式

norflash_io_init();

DelayMs(100);

LPC_EMC->StaticConfig0 &= ~(3<<0);  //

LPC_EMC->StaticConfig0 |= (1<<0);   //设置总线宽度16位

LPC_EMC->StaticConfig0 |= (1<<7);   //设置读写有效电平,读为低电平

LPC_EMC->StaticWaitWen0 &= ~(7<<0);

LPC_EMC->StaticWaitWen0 |= (2<<0);//设置片选到写使能的延时时间

LPC_EMC->StaticWaitOen0 &= ~(7<<0);

LPC_EMC->StaticWaitOen0 |= (2<<0);//设置片选到输出使能的延时

LPC_EMC->StaticWaitWr0 &= ~(0x1f<<0);

LPC_EMC->StaticWaitWr0 |= (0x1f<<0);//设置片选到写入的延时

LPC_EMC->StaticWaitPage0 &= ~(0x1f<<0);

LPC_EMC->StaticWaitPage0 |= (0x1f<<0);//设置读模式顺序存取延时

LPC_EMC->StaticWaitRd0 &= ~(0x1f<<0);

LPC_EMC->StaticWaitRd0 |= (0x1f<<0);//设置片选到读取的延时

LPC_EMC->StaticWaitTurn0 &= ~(0x1f<<0);

LPC_EMC->StaticWaitTurn0 |= (0x1f<<0);//设置总线周转周期

DelayMs(100);

}

void norflash_erase(void)

{

volatile uint16_t *ip;

ip  = GET_ADDR(0x5555);

*ip = 0x00AA;

ip  = GET_ADDR(0x2AAA);

*ip = 0x0055;

ip  = GET_ADDR(0x5555);

*ip = 0x0080;

ip  = GET_ADDR(0x5555);

*ip = 0x00AA;

ip  = GET_ADDR(0x2AAA);

*ip = 0x0055;

ip  = GET_ADDR(0x5555);

*ip = 0x0010;

DelayMs(10);                /* Use timer 1 */

return;

}

//检查nand id

u32 norflash_check_id(void)

{

volatile uint16_t *ip;

uint16_t SST_id1, SST_id2;

/*  Issue the Software Product ID code to 39VF160   */

ip  = GET_ADDR(0x5555);

*ip = 0x00AA;

ip  = GET_ADDR(0x2AAA);

*ip = 0x0055;

ip  = GET_ADDR(0x5555);

*ip = 0x0090;

DelayMs(10);

/* Read the product ID from 39VF160 */

ip  = GET_ADDR(0x0000);

SST_id1 = *ip & 0x00FF;

ip  = GET_ADDR(0x0001);

SST_id2 = *ip;

/* Issue the Soffware Product ID Exit code thus returning the 39VF160 */

/* to the read operating mode */

ip  = GET_ADDR(0x5555);

*ip = 0x00AA;

ip  = GET_ADDR(0x2AAA);

*ip = 0x0055;

ip  = GET_ADDR(0x5555);

*ip = 0x00F0;

DelayMs(10);

/* Check ID */

if ((SST_id1 == SST_ID) && (SST_id2 ==SST_39VF160))

{

return( 0 );

}

else

{

printf("SST_id1 = %x \r\n",SST_id1);

printf("SST_id2 = %x \r\n",SST_id2);

return( 1 );

}

}

//写入数据,只能16位写入

u32 norflash_write_word(u32 add, u16 data)

{

volatile uint16_t *ip;

ip  = GET_ADDR(0x5555);

*ip = 0x00AA;

ip  = GET_ADDR(0x2aaa);

*ip = 0x0055;

ip  = GET_ADDR(0x5555);

*ip = 0x00A0;

ip = GET_ADDR(add);       /* Program 16-bit word */

*ip = data;

return ( norflash_toggle_bit_check( add, data ) );

}

//数据写入检查

u32 norflash_toggle_bit_check(u32 addr,u16 data)

{

volatile u16 *ip;

u16 temp1, temp2;

u32 TimeOut = PROGRAM_TIMEOUT;

while( TimeOut > 0 )

{

ip = GET_ADDR(addr);

temp1 = *ip;

ip = GET_ADDR(addr);

temp2 = *ip;

if ( (temp1 == temp2) && (temp1 == data) )

{

return( 0 );

}

TimeOut--;

}

printf("temp1 = %x \r\n",temp1);

printf("temp2 = %x \r\n",temp2);

return ( 1 );

}

LPC1788的EMC驱动norflash的更多相关文章

  1. lPC1788的GPIO驱动

    #include "led.h" void led_init(void) { //p1.14 p0.16 p1.13 p4.27 LPC_SC->PCONP |= (1< ...

  2. 单片机STM32在开发中常用库函数详解

    1.GPIO初始化函数 用法: voidGPIO_Configuration(void) { GPIO_InitTypeDefGPIO_InitStructure;//GPIO状态恢复默认参数 GPI ...

  3. stm32中的串口通信你了解多少

    在基础实验成功的基础上,对串口的调试方法进行实践.硬件代码顺利完成之后,对日后调试需要用到的printf重定义进行调试,固定在自己的库函数中. b) 初始化函数定义: void USART_Confi ...

  4. 嵌入式物联网之SPI接口原理与配置

    本实验采用W25Q64芯片 W25Q64是华邦公司推出的大容量SPI FLASH产品,其容量为64Mb.该25Q系列的器件在灵活性和性能方面远远超过普通的串行闪存器件.W25Q64将8M字节的容量分为 ...

  5. stm32学习笔记之串口通信

    在基础实验成功的基础上,对串口的调试方法进行实践.硬件代码顺利完成之后,对日后调试需要用到的printf重定义进行调试,固定在自己的库函数中. b) 初始化函数定义: void USART_Confi ...

  6. STM32的串口通信

    本篇文章主要讲解一个在开发过程中经常使用到的一个外设---串口. 串口是绝大多数 MCU 中不可或缺的一个外设,同时也是我们开发中经常使用的一种调试手段,所以在STM32的学习中,串口的配置使用也是必 ...

  7. USART波特率 vs SPI速率--学习笔记

    本篇文章将与大家探讨USART波特率 vs SPI速率.这里提出一个问题,为什么USART的波特率是内核时钟的1/8或者1/16,而SPI最快的频率可以是内核时钟的1/2. 请大家带着这个问题来阅读本 ...

  8. LPC1788 nand驱动

    Lpc 1788自带有emc接口用于驱动nandflash,norflash,sdram设备,对于nandflash驱动因为配置简单,时序也简单 首先,针对nandflash而言应当在系统中有三个地址 ...

  9. lPC1788驱动SDRAM

    Sdram型号为hy57v256 #ifndef __SRAM_H_ #define __SRAM_H_ #include "common.h" #include "de ...

随机推荐

  1. 理解交互设计之"行为设计与对象设计"

    本文是辛向阳教授在<装饰>杂志(大家可以关注这个权威杂志的公众号,分享给大家)2015年第1期公开发表的学术论文,文章探讨的是交互设计研究 思路的转变.这一转变不仅适用于交互设计,也适用于 ...

  2. Loadrunner之文件的下载(八)

    老猪提供: https://mp.weixin.qq.com/s?__biz=MzIwOTMzNDEwNw==&mid=100000013&idx=1&sn=624f5bc74 ...

  3. 转:Selenium2.0 click()不生效的解决办法

    除了http://573301735.com/?p=5126讲的,昨天又发现一个让我1个小时生不如死的问题,就是使用两个不同的配置文件来初始化driver,findelement方法获取到的坐标居然不 ...

  4. HDU 1824 Let's go home

    2-SAT,根据题意建好图,求一下强联通分量,判断一下就可以了 #include<cstdio> #include<cstring> #include<cmath> ...

  5. Chapter 1 First Sight——17

    Once I got around the cafeteria, building three was easy to spot. 我一走出自助餐厅,很容易看见建筑三. A large black & ...

  6. js实现类似于add(1)(2)(3)调用方式的方法

    群里有人说实现类似add(1)(2)(3)调用方式的方法,结果马上有人回答: var add = function(a){ return function(b){ return function(c) ...

  7. Java项目开发第二天

    相对来说今天还是轻松了挺多的,好了,刚刚跑完步,今天心情不错,直接进入主题,就不废话了. (PS:室友都去准备迎新了,老大也是,还好都将课本留给我了,可以好好的看看书了,好好学习,天天向上.) 图形用 ...

  8. C#实现拷贝对象

    大家都知道,在C#中变量的存储分为值类型和引用类型两种,而值类型和引用类型在数值变化是产生的后果是不一样的,值类型我们可以轻松实现数值的拷贝,那么引用类型呢,在对象拷贝上存在着一定的难度.     下 ...

  9. 表单提交中记得form表单放到table外面

    帝国后台按栏目搜索文章时怎么都不生效  控制台查看原来是 栏目的select的值没有提交过去,原来由于form标签在table标签里面,导致js生成的<select>标签提交失败. 解决办 ...

  10. WebSphere MQ 入门指南【转】

    WebSphere MQ 入门指南 转自 WebSphere MQ 入门指南 - 大CC - 博客园http://www.cnblogs.com/me115/p/3456407.html 这是一篇入门 ...