热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

2017-3-4学习笔记

1.1课:怎么看原理图之GPIO和门电路(1)GPIO和门电路:输入输出引脚,三极管,上拉下拉电阻,与或非门等等(2)协议类接口(双方约定信号的协议,双方满足时序要求)<1>U

1.1课:怎么看原理图之GPIO和门电路

(1)GPIO和门电路:输入输出引脚,三极管,上拉下拉电阻,与或非门等等

(2)协议类接口(双方约定信号的协议,双方满足时序要求)

<1>UART:

<2>IIC

<3>SPI

<4>NAND:

怎么设置时序:

(1)看2440手册,确定能设置什么参数;

(2)看外设手册,入nandflash,确定取值;

(3)计算,看2440,看看怎么计算,看看参数的含义;

<5>LCD:

VClock:电子枪 没来一个时钟移动一个信号;

HSYNC:水平方向换行(同步)信号;一行320个点

       VSync:垂直方向的同步信号;240行后调回第一行

       VD0~VD23:数据,RGB等等;

       DE:数据使能;

视频数据从哪来?

分配一个显存SDRAM。将数据扔给信号线,打出来,再去取;不断循环。

怎么设置时序?

1.弄清2440能设置哪些值,这些值得含义是什么。

2.看LCD手册,弄清楚这些值取什么值。

3.计算,这些值是以多少个时钟为单位的,这些值是多少秒,换算成是多少时钟,再将这些时钟也写入2440寄存器中。

 

<6>总结协议类:

连线,不说了;

理解代码,弄清楚数据怎么传输?各引脚怎么配合;

设置时序:2440发出的各个信号,要让外界的芯片能反应过来;

(1)看2440手册弄清楚能设置哪些参数,这些参数的含义;(以CLK为单位)

(2)看外设芯片手册,弄清楚这些参数的取值范围;(以秒为单位)

(3)根据前两条计算2440的寄存器取值;

注:关于设计时序,通过时序写程序在第二期视频也有详细讲到,后续继续关注,韦老大的书中各个章节也有讲每种硬件的配置等等内容。

 

(3)类似内存的接口

<1>NOR,SDRAM,网卡,(书第六章讲的很详细,再详细的时序图第二期有讲)

<2>不同位宽外设的接线,访问过程(16或者32位的外设访问时不同)

<3>怎么确定访问地址,设置内存控制器

 

Q1:地址线,数据线上接有众多的设备,怎么样做到只访问其中一个,其他的不受影响?

A1:每一个芯片都有自己的片选引脚,访问之前,CS信号都设置低电平(低电平有效),其他的芯片CS拉高。

 

Q2:CS是否需要手工来设置?

A2:不需要。2440内有一个内存控制器,CPU访问某个地址时,CPU发出地址信号给“”“内存控制器”,内存控制器根据该地址决定让哪一个CS输出低电平。见书P88上方的表,访问每个存储器,CPU的内存控制器的寄存器的地址是不同的


推荐阅读
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 基于事件驱动的并发编程及其消息通信机制的同步与异步、阻塞与非阻塞、IO模型的分类
    本文介绍了基于事件驱动的并发编程中的消息通信机制,包括同步和异步的概念及其区别,阻塞和非阻塞的状态,以及IO模型的分类。同步阻塞IO、同步非阻塞IO、异步阻塞IO和异步非阻塞IO等不同的IO模型被详细解释。这些概念和模型对于理解并发编程中的消息通信和IO操作具有重要意义。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • C++字符字符串处理及字符集编码方案
    本文介绍了C++中字符字符串处理的问题,并详细解释了字符集编码方案,包括UNICODE、Windows apps采用的UTF-16编码、ASCII、SBCS和DBCS编码方案。同时说明了ANSI C标准和Windows中的字符/字符串数据类型实现。文章还提到了在编译时需要定义UNICODE宏以支持unicode编码,否则将使用windows code page编译。最后,给出了相关的头文件和数据类型定义。 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • 本文讨论了在iOS平台中的Metal框架中,对于if语句中的判断条件的限制和处理方式。作者提到了在Metal shader中,判断条件不能写得太长太复杂,否则可能导致程序停留或没有响应。作者还分享了自己的经验,建议在CPU端进行处理,以避免出现问题。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • RouterOS 5.16软路由安装图解教程
    本文介绍了如何安装RouterOS 5.16软路由系统,包括系统要求、安装步骤和登录方式。同时提供了详细的图解教程,方便读者进行操作。 ... [详细]
  • 记录一次es集群load过高问题(待更新)
    toptop-H-ppid按shiftp以cpu来排序按shiftm以memory来排序将10进制线程pid转为16进制printf%x\npidjstackjstackP ... [详细]
author-avatar
沙尘jr暴的天下
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有