中易网

U盘是怎么工作的,原理又是什么

答案:3  悬赏:50  
解决时间 2021-02-18 00:38
U盘是怎么工作的,原理又是什么
最佳答案
U盘主要一个控制芯片 + Memory (nand Flash )+USB接口
控制芯片 是一个驱动作用
Flash 是常说的内存芯片
Flash Memory的标准物理结构称之为位(cell),其特色为一般MOS的闸极(Gate)和通道的间隔为氧化层之绝缘(gate oxide),而Flash Memory在控制闸(Control gate)与通道间却多了一层物质,称之为浮闸(floating gate)。拜这层浮闸之赐,使得Flash Memory可以完成三种基本操作模式,亦即读(byte或word)、写(byte或word)、抹除(一个或多个内存空间),就算在不提供电源给内存的环境下,也能透过此浮闸,保存数据的完整性。
由于浮闸的物理特性与结构,使得当浮闸被注入负电子时,此一位就由数字"1"被写成"0";相对的当负电子从浮闸中移走后,此一位就由数字"0"变成"1",此过程称之为抹除。目前产业界有许多将负电子注入浮闸或移除技术的探讨,其中热电子注入法(hot-electron injection),是当源极(source)接地,控制闸的电压大于汲极(Drain)的电压时,浮闸与通道间氧化层的能量带会变得很狭隘,因此在通道中的负电子会被加速自通道上跳到浮闸中,进而完成写的动作。同样的原理可以运用在抹除的功能上,当控制闸接地且源极接至一个高压时,浮闸上的负电子将会自浮闸中拉至源极,进而完成抹除的动作。Flash Memory就是透过这种负电子存放或移除于浮闸的原理,使得本身具有重复读写的特性。
全部回答
U盘是采用Flash芯片存储的,Flash芯片属于电擦写电门。在通电以后改变状态,不通电就固定状态。所以断电以后资料能够保存。 Flash芯片的擦写次数在10万次以上,...

一、 u盘基本工作原理

通用串行总线(universal serial bus)是一种快速灵活的接口,
当一个usb设备插入主机时,由于usb设备硬件本身的原因,它会使usb总线的数据信号线的电平发生变化,而主机会经常扫描usb总线。当发现电平有变化时,它即知道有设备插入。
当usb设备刚插入主机时,usb设备它本身会初始化,并认为地址是0。也就是没有分配地址,这有点象刚进校的大学生没有学号一样。
正如有一个陌生人闯入时我们会问“你是什么人”一样,当一个usb设备插入主机时,,它也会问:“你是什么设备”。并接着会问,你使用什么通信协议等等。当这一些信息都被主机知道后,主机与usb设备之间就可以根据它们之间的约定进行通信。
usb的这些信息是通过描述符实现的,usb描述符主要包括:设备描述符,配置描述符,
接口描述符,端点描述符等。当一个u盘括入主机时,你立即会发现你的资源管理器里多了一个可移动磁盘,在win2000下你还可以进一步从主机上知道它是爱国者或是朗科的。这里就有两个问题,首先主机为什么知道插入的是移动磁盘,而不是键盘或打印机等等呢?另外在win2000下为什么还知道是哪个公司生产的呢?其实这很简单,当usb设备插入主机时,主机首先就会要求对方把它的设备描述符传回来,这些设备描述符中就包含了设备类型及制造商信息。又如传输所采用的协议是由接口描述符确定,而传输的方式则包含在端点描述符中。
usb设备分很多类:显示类,通信设备类,音频设备类,人机接口类,海量存储类.特定类的设备又可分为若干子类,每一个设备可以有一个或多个配置,配置用于定义设备的功能。配置是接口的集合,接口是指设备中哪些硬件与usb交换信息。每个与usb交换信息的硬件是一个端点。因些,接口是端点的集合。
u盘应属于海量存储类。
usb海量存储设备又包括通用海量存储子类,cdrom,tape等,u盘实际上属于海量存储类中通用海量存储子类。通用海量存储设备实现上是基于块/扇区存储的设备。
usb组织定义了海量存储设备类的规范,这个类规范包括4个独立的子类规范。主要是指usb总线上的传输方法与存储介质的操作命令。
海量存储设备只支持一个接口,即数据接口,此接口有三个端点bulk input ,bulk output,中断端点
这种设备的接口采用scsi-2的直接存取设备协议,usb设备上的介质使用与scsi-2以相同的逻辑块方式寻址

二、 bulk-only传输协议
当一个u盘插入主机以后,主机会要求usb设备传回它们的描述符,当主机得到这些描述符后,即完成了设备的配置。识别出usb设备是一个支持bulk-only传输协议的海量存储设备。这时应可进行bulk-only传输方式。在此方式下usb与设备之间的数据传输都是通过bulk-in和bulk-out来实现的。
在这种传输方式下,有三种类型数据在usb和设备传送,它们是命令块包(cbw),命令执行状态包(csw)和普通数据包。cbw是主机发往设备的命令。格式如下:
其中dcbwsignature的值为43425355h,表示当前发送的是一个cbw。
dcbwdatatransferlength:表示这次cbw要传送数据长度。
bmcbwflags:表示本次cbw是读数据还是写数所
bbwcblength:表示命令的长度。
cbwcb:表示本次命令内容。也即是scsi命令。
当设备从主机收到cbw块以后,它会把scsi命令从cbw中分离出来,然后根据要求执行,执行的结果又以csw的形式发给主机。
csw的格式如下:
其中dcswsignature的值为53425355h,表示当前发送的是一个csw。
dcswtag:必须和cbw中dcbwtag一样。
dcswdataresidue:还要传送的数据。
bcswstatue:命令执行状态,命令正确执行时,为0。

三、 scsi命令集

在bulk-only的命令块包(cbw)中,有一段cbecb内容,它就是scsi命令块描述符。其内容如下:
operation code:是scsi命令操作代码。
logical block address:逻辑块地址,对u盘而言应是扇区。前面已经讲过:通用海量存储设备是一个基于块/扇区存储的设备,因此在scsi中要提供这个参数是很显然的。
transfer length:为要传送的扇区数
scsi中直接存取类型的存储介质的传输命令有很多,如:
inquiry:其操作码为12h
test unit ready:其操作码为00h
format unit:其操作码为04h
.......
这里以inquiry命令为例:
inquiry命令描述符如下:
inquiry的结果是

u盘供电电路原理

u盘供电电路故障检修

u盘的结构

u盘的电路结构

u盘调试的主要步骤和内容

usb 设备端的固件分以下几个层次:

文件模块名称 主要功能


main.c 进行各种初始化操作、寄存器设置、中断设置

fat16.c flash.c 负责按照fat16 文件系统的组织向flash 中写入数据或是从flash 中读出数据

chap9.c bulk-only.c 完成不同的中断请求,chap9 完成来自端点0 的usb 标准设备请求,bulk-only 完成来自批量模式端点的mass storage bulk-only 传输中断请求

isr.c 中断服务程序,负责将不同类型的中断转向一同的地方

d12ci.c 函数化的d12 的命令集合,可以直接调用这些函数,而不必再自己根据手册查每个命令的代码另外,此文件中包括一些与硬盘有关的地址定义在调试的时候,从现象上来看,分成以下几个阶段性的步骤:

1、usb 芯片正常工作,可以实现软连接,此时pc 机上会出现“未知设备类型”的usb 设备;

2、使用他人已经高度成功的usb 通用接口,按普通usb 设备提供描述符,提供正确的vid 和pid 后,pc 能够识别设备,但要求提供设备的驱动程序;

3、安装驱动程序后,调试几个端点,使其均可传输数据,用pc 端的测试程序对其进行测试,验证硬件及固件的正确性;

4、按mass storagebulk-only 模式提供描述符,pc 机上设备类型变成mass storage device;

5、响应了bulk-only 的inquiry 命令,可以出现盘符了,但尚无法访问磁盘;

6、提供了其他所有的ufi命令(scsi 子集),开始读取磁盘0 扇区(bpb 区)的内容,按照fat16 的格式格式化flash,可以正确读取信息,可以访问盘符,列目录为空;

7、创建文件时,向设备发出write 命令,调整flash 的读写问题,解决写某几个扇区要先保存整个簇的内容,然后擦除整簇,再回写,可以正常创建文件;

8、完成最后的调试,u 盘高度完毕。

在此基础上,还需要提供支持fat16 的文件系统接口函数,比如,可以从fat16 中读取文件,可以创建文件并将其保存到fat16 中去。

u盘维修技术常见故障维修

以下故障在维修时,首先要排除usb接口损坏及pcb板虚焊、及usb延长线正常的情况下,再维修判断

  1、u盘插到机器上没有任何反应

  维修思路:根据故障现象判断,u盘整机没有工作,而u盘工具所要具备的条件也就是我们维修的重点。无论任何方案的u盘想要工具都必须具备以下几个条件:
  (1)供电,分为主控所需的供电和flash所需的供电,这两个是关键,而u盘电路非常的简单,如没有供电一般都是保险电感损坏或3.3v稳压块损坏,说到稳压块再这里也说一下,其有三个引脚分别是电源输入(5v)、地、电源输出(3.3),工作原理就是当输入脚输入一个5v电压时,输出脚就会输出一个稳定的3.3v。只要查到哪里是没有供电的根源,问题就会很好解决了。
  (2)时钟,因主控要在一定频率下才能工作,跟flash通信也要*时钟信号进行传输,所以如果时钟信号没有,主控一定不会工作的。而在检查这方面电路的时候,其实时钟产生电路很简单,只需要检查晶振及其外围电路即可,因晶振怕刷而u盘小巧很容易掉在地上造成晶振损坏,只要更换相同的晶振即可。注意:晶振是无法测量的,判断其好坏最好的方法就是代换一个好的晶振来判断。
  (3)主控,如果上述两个条件都正常那就是主控芯片损坏了。只要更换主控了。

  2、u盘插入电脑,提示“无法识别的设备”。

  维修思路:对于此现象,首先的一点说明u盘的电路基本正常,而只是跟电脑通信方面有故障,而对于通信方面有以下几点要检查:
  (1)u盘接口电路,此电路没有什么特别元件就是两根数据线d d-,所以在检查此电路时只要测量数据线到主控之间的线路是否正常即可,一般都在数据线与主控电路之间会串接两个小阻值的电阻,以起到保护的作用,所以要检查这两个电阻的阻值是否正常。
  (2)时钟电路,因u盘与电脑进行通信要在一定的频率下进行,如果u盘的工作频率和电脑不能同步,那么系统就会认为这是一个“无法识别的设备”了。这时就要换晶振了。而实际维修中真的有很多晶振损坏的实例!
  (3)主控,如果上述两点检查都正常,那就可以判断主控损坏了。

  3、可以认u盘,但打开时提示“磁盘还没有格式化”但系统又无法格式化,或提示“请插入磁盘”,打开u盘里面都是乱码、容量与本身不相符等。

  维修思路:对于此现象,可以判断u盘本身硬件没有太大问题,只是软件问题而以了。
  解决方法:找到主控方案的修复工具搞一下就可以了。这个就要大家自己看u盘的主控是什么方案的来决定了。

  u盘故障大概也就是这些主要问题了。而对于无法写文件、不存储等现象,一般都是flash性能不良或有坏块而引起的。大家看完之后有没有一个清晰的思路了呢。随便说明一下,u盘不同于mp3,他不存在固件之说,但有些厂家把自己的软件放到里面,低格一下就会没有的。

  告诉大家一个非常简单的方法,就是在碰到主控损坏或找不到相应的修复工具时,可以用u盘套件来重新搞一个新的u盘,方法就是把故障机的flash拆下来,放到新的pcb板上就可以了。u盘套件包括(pcb带主控(分1.1和2.0之分)及外壳一套)23元,中维在线有出售,维修起来非常简单,做数据恢复就更方便了。

我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯