TMS320VC5509使用nof flash AM29LV400

2024-01-15 02:50

本文主要是介绍TMS320VC5509使用nof flash AM29LV400,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 硬件接口如下,其中nor flash的使用方法,写的时候和NAND FLASH是一样的,读的时候和DRAM是一样的

2. 看下擦除指令和编程指令

3. 代码如下

#include <csl.h>
#include <csl_pll.h>
#include <csl_emif.h>
#include <csl_chip.h>
#include <stdio.h>
#include <csl_gpio.h>//#define AM29_FLASH_ADDR_BEGIN   (*((unsigned int *)0x200000))
#define AM29_FLASH_ADDR_BEGIN   ((unsigned int *)0x200000)
#define DATA_BUF_LEN 20
/*锁相环的设置*/
PLL_Config  myConfig      = {0,    //IAI: the PLL locks using the same process that was underway//before the idle mode was entered1,    //IOB: If the PLL indicates a break in the phase lock,//it switches to its bypass mode and restarts the PLL phase-locking//sequence6,    //PLL multiply value; multiply 12 times12             //Divide by 2 PLL divide value; it can be either PLL divide value//(when PLL is enabled), or Bypass-mode divide value//(PLL in bypass mode, if PLL multiply value is set to 1)
};
/*SDRAM的EMIF设置*/
EMIF_Config emiffig = {0x221,     //EGCR  : the MEMFREQ = 00,the clock for the memory is equal to cpu frequence//          the WPE = 0 ,forbiden the writing posting when we debug the EMIF//        the MEMCEN = 1,the memory clock is reflected on the CLKMEM pin//        the NOHOLD = 1,HOLD requests are not recognized by the EMIF0xFFFF,    //EMI_RST: any write to this register resets the EMIF state machine0x3FFF,    //CE0_1:  CE0 space control register 1//        MTYPE = 011,Synchronous DRAM(SDRAM),16-bit data bus width0xFFFF,   //CE0_2:  CE0 space control register 20x00FF,   //CE0_3:  CE0 space control register 3//        TIMEOUT = 0xFF;0x1FFF,    //CE1_1:  CE0 space control register 1//        Asynchronous, 16Bit0xFFFF,    //CE1_2:  CE0 space control register 20x00FF,    //CE1_3:  CE0 space control register 30x1FFF,    //CE2_1:  CE0 space control register 1//        Asynchronous, 16Bit0xFFFF,    //CE2_2:  CE0 space control register 20x00FF,    //CE2_3:  CE0 space control register 30x1FFF,    //CE3_1:  CE0 space control register 10xFFFF,    //CE3_2:  CE0 space control register 20x00FF,    //CE3_3:  CE0 space control register 30x2911,   //SDC1:   SDRAM control register 1//          TRC = 8//        SDSIZE = 0;SDWID = 0//        RFEN = 1//        TRCD = 2//        TRP  = 20x0410,    //SDPER : SDRAM period register//          7ns *40960x07FF,    //SDINIT: SDRAM initialization register//        any write to this register to init the all CE spaces,//        do it after hardware reset or power up the C55x device0x0131    //SDC2:      SDRAM control register 2//        SDACC = 0;//        TMRD = 01;//        TRAS = 0101;//        TACTV2ACTV = 0001;
  };
void  delay(unsigned int d_time)
{unsigned int loop = 0;while(d_time--){loop = 1000;while(loop--);}
}Uint16    ChipErase(void)
{Uint16    i,Data;Uint32    TimeOut;*(AM29_FLASH_ADDR_BEGIN + 0x555) = 0xAA;*(AM29_FLASH_ADDR_BEGIN + 0x2AA) = 0x55;*(AM29_FLASH_ADDR_BEGIN + 0x555) = 0x80;*(AM29_FLASH_ADDR_BEGIN + 0x555) = 0xAA;*(AM29_FLASH_ADDR_BEGIN + 0x2AA) = 0x55;*(AM29_FLASH_ADDR_BEGIN + 0x555) = 0x10;i = 0;TimeOut = 0;delay(8000);while(i<5){Data = *(AM29_FLASH_ADDR_BEGIN +  0x1FF);if    (Data == 0xFFFF)    i++;else    i=0;if ( ++TimeOut>0x1000000)    return (0);}for    (i=0;i<0x400;i++){Data = *(AM29_FLASH_ADDR_BEGIN + i);if (Data !=0xFFFF)    return (0);}return  (1);}Uint16    FlashWrite(Uint32    RomStart, Uint16*   buf_start,  Uint16    Length)
{Uint32    i,TimeOut;Uint16    Data1,Data2,j;for    (i=0;i<Length;i++){*(AM29_FLASH_ADDR_BEGIN + 0x555)= 0xAA;*(AM29_FLASH_ADDR_BEGIN + 0x2AA)= 0x55;*(AM29_FLASH_ADDR_BEGIN + 0x555) = 0xA0;*(AM29_FLASH_ADDR_BEGIN + RomStart + i) = *(buf_start++);TimeOut = 0;j=0;delay(10);}while(j<5){Data1 = *(AM29_FLASH_ADDR_BEGIN + RomStart + i);Data2 = *(AM29_FLASH_ADDR_BEGIN + RomStart + i);if    (Data1 == Data2)    j++;else    j=0;if ( ++TimeOut>0x1000000)    return (0);}return  (1);
}void    FlashRead(Uint32    RomStart, Uint16*   buf_start,    Uint16    Length){Uint32    i;for    (i=0;i<Length;i++){*(buf_start++) =  (*((volatile    unsigned  int  *)(AM29_FLASH_ADDR_BEGIN + RomStart + i)));}}main()
{Uint16 data_buf[DATA_BUF_LEN] = {0};unsigned int i = 0;Uint16 write_buf[DATA_BUF_LEN] = {0x0001,0x0002,0x0003,0x0004,0x0005,0x0006,0x0007,0x0008,0x0009,0x0000,0x0011,0x0012,0x0013,0x0014,0x0015,0x0016,0x0017,0x0018,0x0019,0x0010};unsigned int test_data = 0;/*初始化CSL库*/CSL_init();/*EMIF为全EMIF接口*/CHIP_RSET(XBSR,0x0a01);/*设置系统的运行速度为144MHz*/PLL_config(&myConfig);/*初始化DSP的EMIF*/EMIF_config(&emiffig);/*确定方向为输出*/GPIO_RSET(IODIR,0xFF);GPIO_RSET(IODATA,0x00);ChipErase();FlashWrite(0, write_buf,  DATA_BUF_LEN);delay(1000);FlashRead(0, data_buf,  DATA_BUF_LEN);for(i=0;i<DATA_BUF_LEN;i++){if(write_buf[i] != data_buf[i]){printf("test data error:%d",i);}}if(i == DATA_BUF_LEN){printf("test data ok");}for(;;);
}

 

转载于:https://www.cnblogs.com/429512065qhq/p/10719804.html

这篇关于TMS320VC5509使用nof flash AM29LV400的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/607408

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念