文章目录FLASH的特点Norflash和nandflashflash的读写flash的存储单位flash的读写过程FLASH的特点可擦写数据可修改可重写访问速度
第12章:实践版OpenMIPS处理器设计与实现
tanfuz
自己动手写CPU阅读笔记
12.1实践版OpenMIPS处理器的设计目标但在实际应用中,程序的体积可能非常大,指令存储器不能集成在FPGA内部了,一般使用FPGA芯片外部的Flash作为指令存储器,同理,一般使用FPGA芯片外部的SDRAM作为数据存储器。因此,为了使OpenMIPS实用化,需要为其添加Flash控制器,SDRAM控制器:更进一步,如果要使用FPGA外部SRAM,那么需要再为OpenMIPS添加SRAM控制
常用存储器
CXDNW
单片机stm32嵌入式硬件笔记存储FlashEEPROM
目录一、存储器的种类二、易失性存储器(RAM)1.DRAM(1)SDRAM(2)DDRSDRAM2.SRAM3.DRAM与SRAM的应用场合三、非易失性存储器1.ROM(1)MASKROM(2)OTPROM(3)EPROM(4)EEPROM2.Flash存储器3.两种Flash存储器使用场合4.EEPROM与Flash区别一、存储器的种类存储器按其存储介质特性主要分为“易失性存储器”和“非易失性存
重定位(一)段的概念引入
C有点难。
javascript开发语言ecmascript
目录1.2440结构图2.测试代码3.段的引入1.2440结构图对于2440来说,cpu可以直接发指令给SRAM、网卡、SDRAM、NORFLASH,但无法直接控制NANDFLASH,必须由NANDFLASH控制器来操作NANDFLASH,但为什么我们的裸机程序烧入NANDFLASH还可以运行呢?这就引入了重定位机制,当程序是NAND启动时,2440会把前4K的代码拷贝到SRAM中运行(由硬件完成
深入了解DRAM和SDRAM:内存带宽的计算与封装形式的奥秘
小明的Fire计划
计算机基础开发语言笔记计算机外设
SSDSDRAMDDRSDRAM简介动态随机存取存储器DRAM(DynamicRandomAccessMemory,DRAM)是一种半导体存储器。其主要的作用原理是利用电荷内存储电荷的数量来代表一个二进制比特(bit)是1还是0。由于在现实中品体管会有漏电电流的现象,导致电客上所存储的电荷数量并不足以正确的判别数据,而导致数据毁损。因此对于DRAM来说,周期性地充电是一个无可避免的要件。由也正是定
vivado 配置内存IP
cckkppll
fpga开发
配置内存IPUltraScale体系结构内存IP支持DDR3和DDR4SDRAM的配置,QDRIIPLUSSRAM和RLDRAM3型接口。截至2015.3,内存IP已被拆分基于内存接口标准和工具流,将其划分为不同的IP。“自定义IP”对话框框包含基本和高级配置选项,其中包括调试。现在记忆I/O分配过程与设计的其余部分合并,IP配置过程与其他AMDIP一致。有关IP配置和管理的更多信息过程,请参阅《
系统移植 day1 tftp简单文件传输协议和nfs网络文件系统的环境搭建
Wexcill
网络php开发语言
一.系统移植1.嵌入式系统的特点三低:功耗低成本低体积小两高:可靠性高安全性高2.通用嵌入式系统硬件一般由一下部分组成微控制器:cpu晶振:提供时钟内存(如:SRAM,SDRAM):运行程序存储器(如:ROM,FLASH,SD,微硬盘):存储程序其他外围设备接口:输入、输出接口:3.嵌入式系统软件组成部分1)有os(操作系统)的软件组成APPkernel驱动层硬件层2)无os的软件组成APP驱动层
bootloader 启动过程详细说明
u影动
REX
今天早上看了一上午的bootloader简单源码,终于捋顺了bootloader的执行过程,之前只是知道bootloader代码会先被irom中的代码拷贝到iram中一部分,然后执行这部分代码,会把整个bootloader代码拷贝到sdram中,最终在sdram执行剩下的代码,而这段代码会把kernel拷贝到sdram的某个地址,最终引导起来整个内核。但是我今天早上看代码的时候看到一个问题,我所有
LINUX DDR驱动知识(转)
玛丽奥ZJY
【SDRAM】
一、DDR原理DDR内存既然叫做双倍速率SDRAM(DualdaterateSDRSM),就是说是SDRAM的升级换代产品。从技术上分析,DDRSDRAM最重要的改变是在界面数据传输上,其在时钟信号上升缘与下降缘时各传输一次数据,这使得DDR的数据传输速率为传统SDRAM的两倍。那么大家就应该知道了,我们所说的DDR400,DDR333,DDR266,他们的工作频率其实仅为那些数值的一半,也就是说
DDR内存时序指南
wujiangguizhen
DDR-内存linux内核内核driver
DDR内存既然叫做双倍速率SDRAM(DualdaterateSDRSM),就是说是SDRAM的升级换代产品。从技术上分析,DDRSDRAM最重要的改变是在界面数据传输上,其在时钟信号上升缘与下降缘时各传输一次数据,这使得DDR的数据传输速率为传统SDRAM的两倍。那么大家就应该知道了,我们所说的DDR400,DDR333,DDR266,他们的工作频率其实仅为那些数值的一半,也就是说DDR400工
南京观海微电子----DDR的工作原理——DDR接口专栏(一)
9亿少女的噩梦
观海微电子显示驱动ICfpga开发
DDR的发展历程SDRAM从发展到现在已经经历了四代,分别是:第一代SDRSDRAM,第二代DDRSDRAM,第三代DDR2SDRAM,第四代DDR3SDRAM,现在已经发展到DDR5SDRAM。DDRSDRAM是DoubleDataRateSynchronousDynamicRandomAccessMemory(双数据率同步动态随机存储器)的简称,为第二代SDRAM标准。其常见标准有DDR266
系统移植 day1 tftp简单文件传输协议和nfs网络文件系统的环境搭建
Wexcill
网络
一.系统移植1.嵌入式系统的特点三低:功耗低成本低体积小两高:可靠性高安全性高2.通用嵌入式系统硬件一般由一下部分组成微控制器:cpu晶振:提供时钟内存(如:SRAM,SDRAM):运行程序存储器(如:ROM,FLASH,SD,微硬盘):存储程序其他外围设备接口:输入、输出接口:3.嵌入式系统软件组成部分1)有os(操作系统)的软件组成APPkernel驱动层硬件层2)无os的软件组成APP驱动层
系统移植及相关介绍
西装没钱买
arm系统移植
一.系统移植系统移植(SystemPorting)是将一个操作系统从一种硬件平台迁移到另一种硬件平台的过程。这个过程涉及将操作系统的内核和相关的软件组件调整和适配到新的硬件环境中。1.嵌入式系统的特点三低:功耗低成本低体积小两高:可靠性高安全性高2.组成通用嵌入式系统硬件一般由一下部分组成微控制器:cpu晶振:提供时钟内存(如:SRAM,SDRAM):运行程序存储器(如:ROM,FLASH,SD,
ARM-Linux驱动内核(S3C2440)
Omedetou。
linuxarm开发运维
Linux启动流程驱动(程序):驱使设备行动的程序1.启动bootloader---引导操作系统启动的(裸机)程序,为操作系统启动准备环境,并引导操作系统启动2.启动kernel---操作系统核心(俗称的操作系统)3.加载根文件系统---一堆文件的集合(根目录下的文件)存储分类RAM(随机存储)SRAM静态DRAM动态SDRAM同步动态SDR(DDR2\3\4\5)ROM(只读存储)PROM可编程
23 SEMC外扩SDRAM
万码无虫
NXP嵌入式硬件
文章目录23.1SDRAM控制原理23.2SEMC简介23.1SDRAM控制原理RT1052系列芯片扩展内存时可以选择SRAM和SDRAM由于SDRAM的“容量/价格”比较高,即使用SDRAM要比SRAM要划算得多。给RT1052芯片扩展内存与给PC扩展内存的原理是一样的PC上一般以内存条的形式扩展,内存条实质是由多个内存颗粒(即SDRAM芯片)组成的通用标准模块RT1052直接与SDRAM芯片连
Xilinx FPGA DDR3设计(三)DDR3 IP核详解及读写测试
FPGA技术实战
fpga开发tcp/ip网络协议
引言:本文我们介绍下XilinxDDR3IP核的重要架构、IP核信号管脚定义、读写操作时序、IP核详细配置以及简单的读写测试。01.DDR3IP核概述7系列FPGADDR接口解决方案如图1所示。图1、7系列FPGADDR3解决方案1.1用户FPGA逻辑(UserFPGALogic)如图1中①所示,用户FPGA逻辑块是任何需要连接到外部DDR2或DDR3SDRAM的FPGA设计。用户FPGA逻辑通过
keil如何查看flash和ram占用情况
每天学习一个知识点
经验分享
KeilMDK编译器下查看占用Flash和SRAM空间大小_keilsdram1k-CSDN博客1、如何查看各函数占用内存大小:keil查看使用的内存还剩多少_keil如何查看空间-CSDN博客
SDRAM小项目——读模块
小天才dhsb
经验分享fpga开发笔记硬件工程其他
根据文档信息,读模块和写模块过程相似,所以直接在写模块上修改信号名称。与写模块不同的是,读模块的数据输出在读命令发出后几个周期才开始输出。读模块代码:modulesdram_read(inputsclk,inputsrst,//communicatewithtopinputrd_en,outputwirerd_req,outputregflag_rd_end,//inputref_req,inpu
SDRAM小项目——命令解析模块
小天才dhsb
fpga开发
简单介绍:在FPGA中实现命令解析模块,命令解析模块的用来把pc端传入FPGA中的数据分解为所需要的数据和触发命令,虽然代码不多,但是却十分重要。SDRAM的整体结构如下,可以看出,命令解析模块cmd_decode负责解析uart_rx中的信息分析:命令解析模块主要分离触发信号和需要写入数据data,uart发送端发送数据55时后表示之后的四组数据应该写入,发送aa则表示读命令,开始读数据。uar
SDRAM小项目——刷新模块
小天才dhsb
javalinux开发语言
记录了SDRAM控制器进行初始化配置后的刷新模块。SDRAM要进行不停地刷新保证数据的存在,因为SDRAM类似于电容,每次放电结束后数据都会丢失,所以要进行不断地刷新,刷新间隔为15us。控制器状态从开始的idle状态到仲裁状态,在仲裁状态下进行刷新,读,写状态的跳转。在仲裁状态下接收到刷新请求,发送刷新使能,状态转到刷新状态,当刷新结束后发送刷新结束标志,状态跳转到仲裁状态。文档信息:首先进行p
html页面js获取参数值
0624chenhong
html
1.js获取参数值js
function GetQueryString(name)
{
var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)");
var r = windo
MongoDB 在多线程高并发下的问题
BigCat2013
mongodbDB高并发重复数据
最近项目用到 MongoDB , 主要是一些读取数据及改状态位的操作. 因为是结合了最近流行的 Storm进行大数据的分析处理,并将分析结果插入Vertica数据库,所以在多线程高并发的情境下, 会发现 Vertica 数据库中有部分重复的数据. 这到底是什么原因导致的呢?笔者开始也是一筹莫 展,重复去看 MongoDB 的 API , 终于有了新发现 :
com.mongodb.DB 这个类有
c++ 用类模版实现链表(c++语言程序设计第四版示例代码)
CrazyMizzz
数据结构C++
#include<iostream>
#include<cassert>
using namespace std;
template<class T>
class Node
{
private:
Node<T> * next;
public:
T data;
最近情况
麦田的设计者
感慨考试生活
在五月黄梅天的岁月里,一年两次的软考又要开始了。到目前为止,我已经考了多达三次的软考,最后的结果就是通过了初级考试(程序员)。人啊,就是不满足,考了初级就希望考中级,于是,这学期我就报考了中级,明天就要考试。感觉机会不大,期待奇迹发生吧。这个学期忙于练车,写项目,反正最后是一团糟。后天还要考试科目二。这个星期真的是很艰难的一周,希望能快点度过。
linux系统中用pkill踢出在线登录用户
被触发
linux
由于linux服务器允许多用户登录,公司很多人知道密码,工作造成一定的障碍所以需要有时踢出指定的用户
1/#who 查出当前有那些终端登录(用 w 命令更详细)
# who
root pts/0 2010-10-28 09:36 (192
仿QQ聊天第二版
肆无忌惮_
qq
在第一版之上的改进内容:
第一版链接:
http://479001499.iteye.com/admin/blogs/2100893
用map存起来号码对应的聊天窗口对象,解决私聊的时候所有消息发到一个窗口的问题.
增加ViewInfo类,这个是信息预览的窗口,如果是自己的信息,则可以进行编辑.
信息修改后上传至服务器再告诉所有用户,自己的窗口
java读取配置文件
知了ing
1,java读取.properties配置文件
InputStream in;
try {
in = test.class.getClassLoader().getResourceAsStream("config/ipnetOracle.properties");//配置文件的路径
Properties p = new Properties()
__attribute__ 你知多少?
矮蛋蛋
C++gcc
原文地址:
http://www.cnblogs.com/astwish/p/3460618.html
GNU C 的一大特色就是__attribute__ 机制。__attribute__ 可以设置函数属性(Function Attribute )、变量属性(Variable Attribute )和类型属性(Type Attribute )。
__attribute__ 书写特征是:
jsoup使用笔记
alleni123
java爬虫JSoup
<dependency>
<groupId>org.jsoup</groupId>
<artifactId>jsoup</artifactId>
<version>1.7.3</version>
</dependency>
2014/08/28
今天遇到这种形式,
JAVA中的集合 Collectio 和Map的简单使用及方法
百合不是茶
listmapset
List ,set ,map的使用方法和区别
java容器类类库的用途是保存对象,并将其分为两个概念:
Collection集合:一个独立的序列,这些序列都服从一条或多条规则;List必须按顺序保存元素 ,set不能重复元素;Queue按照排队规则来确定对象产生的顺序(通常与他们被插入的
杀LINUX的JOB进程
bijian1013
linuxunix
今天发现数据库一个JOB一直在执行,都执行了好几个小时还在执行,所以想办法给删除掉
系统环境:
ORACLE 10G
Linux操作系统
操作步骤如下:
第一步.查询出来那个job在运行,找个对应的SID字段
select * from dba_jobs_running--找到job对应的sid
&n
Spring AOP详解
bijian1013
javaspringAOP
最近项目中遇到了以下几点需求,仔细思考之后,觉得采用AOP来解决。一方面是为了以更加灵活的方式来解决问题,另一方面是借此机会深入学习Spring AOP相关的内容。例如,以下需求不用AOP肯定也能解决,至于是否牵强附会,仁者见仁智者见智。
1.对部分函数的调用进行日志记录,用于观察特定问题在运行过程中的函数调用
[Gson六]Gson类型适配器(TypeAdapter)
bit1129
Adapter
TypeAdapter的使用动机
Gson在序列化和反序列化时,默认情况下,是按照POJO类的字段属性名和JSON串键进行一一映射匹配,然后把JSON串的键对应的值转换成POJO相同字段对应的值,反之亦然,在这个过程中有一个JSON串Key对应的Value和对象之间如何转换(序列化/反序列化)的问题。
以Date为例,在序列化和反序列化时,Gson默认使用java.
【spark八十七】给定Driver Program, 如何判断哪些代码在Driver运行,哪些代码在Worker上执行
bit1129
driver
Driver Program是用户编写的提交给Spark集群执行的application,它包含两部分
作为驱动: Driver与Master、Worker协作完成application进程的启动、DAG划分、计算任务封装、计算任务分发到各个计算节点(Worker)、计算资源的分配等。
计算逻辑本身,当计算任务在Worker执行时,执行计算逻辑完成application的计算任务
nginx 经验总结
ronin47
nginx 总结
深感nginx的强大,只学了皮毛,把学下的记录。
获取Header 信息,一般是以$http_XX(XX是小写)
获取body,通过接口,再展开,根据K取V
获取uri,以$arg_XX
&n
轩辕互动-1.求三个整数中第二大的数2.整型数组的平衡点
bylijinnan
数组
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class ExoWeb {
public static void main(String[] args) {
ExoWeb ew=new ExoWeb();
System.out.pri
Netty源码学习-Java-NIO-Reactor
bylijinnan
java多线程netty
Netty里面采用了NIO-based Reactor Pattern
了解这个模式对学习Netty非常有帮助
参考以下两篇文章:
http://jeewanthad.blogspot.com/2013/02/reactor-pattern-explained-part-1.html
http://gee.cs.oswego.edu/dl/cpjslides/nio.pdf
AOP通俗理解
cngolon
springAOP
1.我所知道的aop 初看aop,上来就是一大堆术语,而且还有个拉风的名字,面向切面编程,都说是OOP的一种有益补充等等。一下子让你不知所措,心想着:怪不得很多人都和 我说aop多难多难。当我看进去以后,我才发现:它就是一些java基础上的朴实无华的应用,包括ioc,包括许许多多这样的名词,都是万变不离其宗而 已。 2.为什么用aop&nb
cursor variable 实例
ctrain
variable
create or replace procedure proc_test01
as
type emp_row is record(
empno emp.empno%type,
ename emp.ename%type,
job emp.job%type,
mgr emp.mgr%type,
hiberdate emp.hiredate%type,
sal emp.sal%t
shell报bash: service: command not found解决方法
daizj
linuxshellservicejps
今天在执行一个脚本时,本来是想在脚本中启动hdfs和hive等程序,可以在执行到service hive-server start等启动服务的命令时会报错,最终解决方法记录一下:
脚本报错如下:
./olap_quick_intall.sh: line 57: service: command not found
./olap_quick_intall.sh: line 59
40个迹象表明你还是PHP菜鸟
dcj3sjt126com
设计模式PHP正则表达式oop
你是PHP菜鸟,如果你:1. 不会利用如phpDoc 这样的工具来恰当地注释你的代码2. 对优秀的集成开发环境如Zend Studio 或Eclipse PDT 视而不见3. 从未用过任何形式的版本控制系统,如Subclipse4. 不采用某种编码与命名标准 ,以及通用约定,不能在项目开发周期里贯彻落实5. 不使用统一开发方式6. 不转换(或)也不验证某些输入或SQL查询串(译注:参考PHP相关函
Android逐帧动画的实现
dcj3sjt126com
android
一、代码实现:
private ImageView iv;
private AnimationDrawable ad;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout
java远程调用linux的命令或者脚本
eksliang
linuxganymed-ssh2
转载请出自出处:
http://eksliang.iteye.com/blog/2105862
Java通过SSH2协议执行远程Shell脚本(ganymed-ssh2-build210.jar)
使用步骤如下:
1.导包
官网下载:
http://www.ganymed.ethz.ch/ssh2/
ma
adb端口被占用问题
gqdy365
adb
最近重新安装的电脑,配置了新环境,老是出现:
adb server is out of date. killing...
ADB server didn't ACK
* failed to start daemon *
百度了一下,说是端口被占用,我开个eclipse,然后打开cmd,就提示这个,很烦人。
一个比较彻底的解决办法就是修改
ASP.NET使用FileUpload上传文件
hvt
.netC#hovertreeasp.netwebform
前台代码:
<asp:FileUpload ID="fuKeleyi" runat="server" />
<asp:Button ID="BtnUp" runat="server" onclick="BtnUp_Click" Text="上 传" />
代码之谜(四)- 浮点数(从惊讶到思考)
justjavac
浮点数精度代码之谜IEEE
在『代码之谜』系列的前几篇文章中,很多次出现了浮点数。 浮点数在很多编程语言中被称为简单数据类型,其实,浮点数比起那些复杂数据类型(比如字符串)来说, 一点都不简单。
单单是说明 IEEE浮点数 就可以写一本书了,我将用几篇博文来简单的说说我所理解的浮点数,算是抛砖引玉吧。 一次面试
记得多年前我招聘 Java 程序员时的一次关于浮点数、二分法、编码的面试, 多年以后,他已经称为了一名很出色的
数据结构随记_1
lx.asymmetric
数据结构笔记
第一章
1.数据结构包括数据的
逻辑结构、数据的物理/存储结构和数据的逻辑关系这三个方面的内容。 2.数据的存储结构可用四种基本的存储方法表示,它们分别是
顺序存储、链式存储 、索引存储 和 散列存储。 3.数据运算最常用的有五种,分别是
查找/检索、排序、插入、删除、修改。 4.算法主要有以下五个特性:
输入、输出、可行性、确定性和有穷性。 5.算法分析的
linux的会话和进程组
网络接口
linux
会话: 一个或多个进程组。起于用户登录,终止于用户退出。此期间所有进程都属于这个会话期。会话首进程:调用setsid创建会话的进程1.规定组长进程不能调用setsid,因为调用setsid后,调用进程会成为新的进程组的组长进程.如何保证? 先调用fork,然后终止父进程,此时由于子进程的进程组ID为父进程的进程组ID,而子进程的ID是重新分配的,所以保证子进程不会是进程组长,从而子进程可以调用se
二维数组 元素的连续求解
1140566087
二维数组ACM
import java.util.HashMap;
public class Title {
public static void main(String[] args){
f();
}
// 二位数组的应用
//12、二维数组中,哪一行或哪一列的连续存放的0的个数最多,是几个0。注意,是“连续”。
public static void f(){
也谈什么时候Java比C++快
windshome
javaC++
刚打开iteye就看到这个标题“Java什么时候比C++快”,觉得很好笑。
你要比,就比同等水平的基础上的相比,笨蛋写得C代码和C++代码,去和高手写的Java代码比效率,有什么意义呢?
我是写密码算法的,深刻知道算法C和C++实现和Java实现之间的效率差,甚至也比对过C代码和汇编代码的效率差,计算机是个死的东西,再怎么优化,Java也就是和C