介绍一款单片机存储设备转储器,以C8051F040为核心控制模块,通过外接两个CH375 U盘模块、液晶显示模块及键盘模块等实现两个U盘之间数据的相互转储,很好地解决了U盘内容转储离不开电脑而带来的不便以及容易感染病毒等弊端。C8051F040通过CH375 按照相应的USB协议与USB设备通讯,通过调用CH375提供的子程序库来直接读取U盘中的数据,实现了普通单片机与U盘的通讯,支持常用的12 Mb/s 全速USB设备和1. 5 Mb/s低速设备。该设计方案具有低成本、低功耗、操作简单等特点,将会有广阔的应用前景。
上传时间: 2013-12-17
上传用户:xzt
WTS701是华邦公司推出的内建喇叭驱动功能的“文字转发音”单芯片集成电路。该芯片将连续运算法与华邦专有的多层次储存技术相结合,从而实现了真正将“文字转发音”的完整功能。文中介绍了该芯片的原理及典型应用,给出了Cygnal F120 MPU与WTS701 的接口电路,并根据相应的芯片指令给出了其控制软件的代码程序。 Abstract: WTS701 is really a single chip on “text-to-speech” produced by Winbond company building-in algorithm with the company's patented multi-level storageMLS technology熏 different from other chips that “text-to-speech” on the market at present. The principle and typical application of this chip are introduced in this article the interface circuit of Cygnal F120 MPU and WTS701 is presented. The corresponding? control software is provided.
上传时间: 2013-10-08
上传用户:旗鱼旗鱼
内有STM32原理图封装和PCB封装
上传时间: 2013-10-10
上传用户:DXM35
The bootloader is stored in the internal boot ROM memory (system memory) of STM32devices. It is programmed by ST during production. Its main task is to download theapplication program to the internal Flash memory through one of the available serialperipherals (USART, CAN, USB, etc.). A communication protocol is defined for each serialinterface, with a compatible command set and sequences
上传时间: 2014-09-06
上传用户:417313137
将AVR上的队列串口驱动程序修改后,运行在STM32开发板,采用中断方式接收和中断发送,并加入了缓冲收发队列操作。由于该驱动是用来操作西门子的TC35或MC55等通信模块,所以加入了“等待串口接收完成”函数,该函数需要一个10ms的定时进行计数累加。
上传时间: 2013-11-11
上传用户:kaixinxin196
摘要:本文主要介绍了使用STM32F103RB芯片的32位闪存微控制器为内核制作一个MP3播放器,此芯片是基于ARMCortex-M3为内核,具有强大的功能。该MP3播放器由上述的微控制器、MP3解码芯片(VS1003)、SD卡(FAT32文件系统)和液晶显示屏(Nokia5110)组成。关键词:STM32;VS1003;SD;FAT32
上传时间: 2013-10-13
上传用户:569342831
目录 第一章 伟福仿真系统说明第一节 伟福仿真系统的使用说明快速入门第一节 分析功能使用第二章 仿真系统构成概述第三章 板上仿真器使用方法第一节 键盘使用说明第二节 脱机仿真第四章 伟福系列实验说明第五章 实验项目软件实验一 存储器块清零软件实验二 二进制到BCD转换软件实验三 二进制到ASCII码转换软件实验四 内存块移动软件实验五 程序跳转表软件实验六 数据排序硬件实验一 P1口输入、输出实验硬件实验二 继电器控制实验硬件实验三 用74LS245读入数据硬件实验四 用74LS273输出数据硬件实验五 音频控制实验硬件实验六 8255输入、输出实验硬件实验七 计数器实验硬件实验八 外部中断实验硬件实验九 定时器实验硬件实验十 外部中断(急救车与交通灯)硬件实验十一 八段数码管显示硬件实验十二 键盘扫描显示实验硬件实验十三 单片机串行口通讯实验硬件实验十四 直流电机控制实验硬件实验十五 步进电机控制实验硬件实验十六 8253计数器实验硬件实验十七 8259外部中断实验硬件实验十八 8253定时器实验硬件实验十九 8251A串行通讯实验附录一 8086实验程序及说明附录二 MCS51实验程序及说明参考书目
上传时间: 2014-11-23
上传用户:GHF
三菱梯形图转51单片机软件使用
上传时间: 2013-11-04
上传用户:离殇
嵌入式CAN转UART模块 CSM100系列产品手册 CSM100系列UART转CAN 模块是集成微处理器、CAN-bus控制器、CAN-bus收发器、DC-DC转换、高速光电隔离于一体的嵌入式CAN转UART模块。
上传时间: 2014-01-03
上传用户:caixiaoxu26
at91rm9200启动过程教程 系统上电,检测BMS,选择系统的启动方式,如果BMS为高电平,则系统从片内ROM启动。AT91RM9200的ROM上电后被映射到了0x0和0x100000处,在这两个地址处都可以访问到ROM。由于9200的ROM中固化了一个BOOTLOAER程序。所以PC从0X0处开始执行这个BOOTLOAER(准确的说应该是一级BOOTLOADER)。这个BOOTLOER依次完成以下步骤: 1、PLL SETUP,设置PLLB产生48M时钟频率提供给USB DEVICE。同时DEBUG USART也被初始化为48M的时钟频率; 2、相应模式下的堆栈设置; 3、检测主时钟源(Main oscillator); 4、中断控制器(AIC)的设置; 5、C 变量的初始化; 6、跳到主函数。 完成以上步骤后,我们可以认为BOOT过程结束,接下来的就是LOADER的过程,或者也可以认为是装载二级BOOTLOER。AT91RM9200按照DATAFLASH、EEPROM、连接在外部总线上的8位并行FLASH的顺序依次来找合法的BOOT程序。所谓合法的指的是在这些存储设备的开始地址处连续的存放的32个字节,也就是8条指令必须是跳转指令或者装载PC的指令,其实这样规定就是把这8条指令当作是异常向量表来处理。必须注意的是第6条指令要包含将要装载的映像的大小。关于如何计算和写这条指令可以参考用户手册。一旦合法的映像找到之后,则BOOT程序会把找到的映像搬到SRAM中去,所以映像的大小是非常有限的,不能超过16K-3K的大小。当BOOT程序完成了把合法的映像搬到SRAM的任务以后,接下来就进行存储器的REMAP,经过REMAP之后,SRAM从映设前的0X200000地址处被映设到了0X0地址并且程序从0X0处开始执行。而ROM这时只能在0X100000这个地址处看到了。至此9200就算完成了一种形式的启动过程。如果BOOT程序在以上所列的几种存储设备中找到合法的映像,则自动初始化DEBUG USART口和USB DEVICE口以准备从外部载入映像。对DEBUG口的初始化包括设置参数115200 8 N 1以及运行XMODEM协议。对USB DEVICE进行初始化以及运行DFU协议。现在用户可以从外部(假定为PC平台)载入你的映像了。在PC平台下,以WIN2000为例,你可以用超级终端来完成这个功能,但是还是要注意你的映像的大小不能超过13K。一旦正确从外部装载了映像,接下来的过程就是和前面一样重映设然后执行映像了。我们上面讲了BMS为高电平,AT91RM9200选择从片内的ROM启动的一个过程。如果BMS为低电平,则AT91RM9200会从片外的FLASH启动,这时片外的FLASH的起始地址就是0X0了,接下来的过程和片内启动的过程是一样的,只不过这时就需要自己写启动代码了,至于怎么写,大致的内容和ROM的BOOT差不多,不同的硬件设计可能有不一样的地方,但基本的都是一样的。由于片外FLASH可以设计的大,所以这里编写的BOOTLOADER可以一步到位,也就是说不用像片内启动可能需要BOOT好几级了,目前AT91RM9200上使用较多的bootloer是u-boot,这是一个开放源代码的软件,用户可以自由下载并根据自己的应用配置。总的说来,笔者以为AT91RM9200的启动过程比较简单,ATMEL的服务也不错,不但提供了片内启动的功能,还提供了UBOOT可供下载。笔者写了一个BOOTLODER从片外的FLASHA启动,效果还可以。 uboot结构与使用uboot是一个庞大的公开源码的软件。他支持一些系列的arm体系,包含常见的外设的驱动,是一个功能强大的板极支持包。其代码可以 http://sourceforge.net/projects/u-boot下载 在9200上,为了启动uboot,还有两个boot软件包,分别是loader和boot。分别完成从sram和flash中的一级boot。其源码可以从atmel的官方网站下载。 我们知道,当9200系统上电后,如果bms为高电平,则系统从片内rom启动,这时rom中固化的boot程序初始化了debug口并向其发送'c',这时我们打开超级终端会看到ccccc...。这说明系统已经启动,同时xmodem协议已经启动,用户可以通过超级终端下载用户的bootloader。作为第一步,我们下载loader.bin.loader.bin将被下载到片内的sram中。这个loder完成的功能主要是初始化时钟,sdram和xmodem协议,为下载和启动uboot做准备。当下载了loader.bin后,超级终端会继续打印:ccccc....。这时我们就可以下在uboot了。uboot将被下载到sdram中的一个地址后并把pc指针调到此处开始执行uboot。接着我们就可以在终端上看到uboot的shell启动了,提示符uboot>,用户可以uboot>help 看到命令列表和大概的功能。uboot的命令包含了对内存、flash、网络、系统启动等一些命令。 如果系统上电时bms为低电平,则系统从片外的flash启动。为了从片外的flash启动uboot,我们必须把boot.bin放到0x0地址出,使得从flash启动后首先执行boot.bin,而要少些boot.bin,就要先完成上面我们讲的那些步骤,首先开始从片内rom启动uboot。然后再利用uboot的功能完成把boot.bin和uboot.gz烧写到flash中的目的,假如我们已经启动了uboot,可以这样操作: uboot>protect off all uboot>erase all uboot>loadb 20000000 uboot>cp.b 20000000 10000000 5fff uboot>loadb 21000000 uboot>cp.b 210000000 10010000 ffff 然后系统复位,就可以看到系统先启动boot,然后解压缩uboot.gz,然后启动uboot。注意,这里uboot必须压缩成.gz文件,否则会出错。 怎么编译这三个源码包呢,首先要建立一个arm的交叉编译环境,关于如何建立,此处不予说明。建立好了以后,分别解压源码包,然后修改Makefile中的编译器项目,正确填写你的编译器的所在路径。 对loader和boot,直接make。对uboot,第一步:make_at91rm9200dk,第二步:make。这样就会在当前目录下分别生成*.bin文件,对于uboot.bin,我们还要压缩成.gz文件。 也许有的人对loader和boot搞不清楚为什么要两个,有什么区别吗?首先有区别,boot主要完成从flash中启动uboot的功能,他要对uboot的压缩文件进行解压,除此之外,他和loader并无大的区别,你可以把boot理解为在loader的基础上加入了解压缩.gz的功能而已。所以这两个并无多大的本质不同,只是他们的使命不同而已。 特别说名的是这三个软件包都是开放源码的,所以用户可以根据自己的系统的情况修改和配置以及裁减,打造属于自己系统的bootloder。
上传时间: 2013-10-27
上传用户:wsf950131