USB(Universal Serial Bus)接口已经成为了很多设备的标配,无论是电脑、手机还是其他物联网设备,几乎所有的现代电子设备都有USB端口。而且,USB接口通常被用来连接未知的外部设备,如键盘,鼠标、自动扫描仪等等。为了确保这些设备与电脑的正常通信,必须保证USB接口工作在良好的状态下。为了检测USB接口的有效性,需使用USB回环测试程序。本文将介绍Linux USB回环程序的详细操作方法,帮助读者通过虚拟的回环测试来检测USB接口的工作状态。
创新互联建站主营井冈山网站建设的网络公司,主营网站建设方案,App定制开发,井冈山h5小程序定制开发搭建,井冈山网站营销推广欢迎井冈山等地区企业咨询
什么是Linux USB回环程序?
这种测试程序是在Linux系统上运行的程序,使用USB端口的设备进行回环测试。简单而言,就是把USB信号从输出端口发送到输入端口,再检测信号是否成功地回到了输出端口。这个模拟过程能够反映出设备是否与USB接口正常通信。
如何安装Linux USB回环程序?
为了运行Linux USB回环测试,需要安装必要的软件包。可以通过以下命令安装:sudo apt-get install uutils
安装完成之后,输入以下命令:lsu, 系统将会显示USB总线上所有连接的设备,这样就可以选择需要测试的设备进行uiotest。
如何运行Linux USB回环程序?
运行USB回环测试程序一般分为以下步骤:
1.打开终端。
在终端中,输入以下命令查看USB接口的名称:
$ dmesg | grep USB
示例输出:
[ 15.334060] u 1-1: new full-speed USB device number 9 using xhci_hcd
[ 15.458459] u 1-1: New USB device found, idVendor=045e, idProduct=07fd, bcdDevice=11.10
[ 15.458468] u 1-1: New USB device strings: Mfr=1, Product=2, SerialNumber=0
[ 15.458473] u 1-1: Product: Microsoft® Basic Optical Mouse v2.0
[ 15.458478] u 1-1: Manufacturer: Microsoft
[ 15.468485] input: Microsoft Microsoft® Basic Optical Mouse v2.0 as /devices/pci0000:00/0000:00:14.0/u1/1-1/1-1:1.0/0003:045E:07FD.000C/input/input30
[ 15.469055] hid-generic 0003:045E:07FD.000C: input,hidraw1: USB HID v1.11 Mouse [Microsoft Microsoft® Basic Optical Mouse v2.0] on u-0000:00:14.0-1/input0
显然,这里的USB接口名称是“/1-1”。在运行回环测试程序之前,一定先要确认要测试的设备是否已经插入USB接口,接口进行标识,这样就可以执行回环测试程序针对该设备进行测试。
2.进行回环测试。
在终端中,运行以下命令可以将回环测试程序加载到系统中:
$ sudo modprobe g_hid
3.利用工具进行测试USB接口的状态。
现在可以使用系统工具测试USB接口的状态。推荐使用以下命令:
$ sudo lsu -v -d VendorID:ProductID | egrep “^(Bus|Device) ” | awk ‘{print $2}’ | xargs -I{} sh -c ‘sudo ./uiotest -D /dev/bus/u/{}// -v -p -i -t 1 -w 5’
示例输出:
Bus 001 Device 005: UIOTest SRL UIOTest device
UIOTest test starting on device /dev/bus/u/001/005
0 0 0 0 0
UIOTest test results: read=393236 write=393216
OK: USB transfer successfull
使用Linux USB回环程序进行测试的优点
1.高效。
使用Linux USB回环程序进行测试的好处之一就是其高效性。测试程序中所有的信息都从一个USB接口经过,这意味着在将信息从一个USB接口发送到另一个USB接口的过程中,其传输速度非常快。
2.精准。
使用Linux USB回环程序进行测试还有一个好处就是其精确性。该程序是开源的,可以自定义各种参数,以确保测试结果的准确性。这些自定义参数包括传输速度、缓冲区大小等等。
3.方便。
使用Linux USB回环程序进行测试还是相对简便的,因为使用单个命令即可运行自定义参数测试。
结论
通过对Linux USB回环程序的介绍和使用方法的探讨,相信读者对于依赖于USB接口工作的设备的正确使用和维护有了更好的了解,同时也为Linux系统下USB接口的回环测试提供了一种更为快捷的方式。知道Linux USB回环程序的使用方法,用户可以自主根据USB接口的需要进行详细的测试,并能够保障设备的正常使用,节省了许多维护成本。
相关问题拓展阅读:
分类: 电脑/网络 >> 操作系统/系统故障
问题描述:
我有一个U盘,256M的,如和制作一个LINUX启动U盘??
解析:
U盘做Linux的启动盘
摘要
本文描述了如何在USB存储设备上建立Linux启动系统的过程。
首先让我们先了解一下LINUX下USB设备, Linux USB 驱动程序有三种不同的 USB 主控制器选项,这是因为在主板和 PCI 卡上有三种不同类型的 USB 芯片。”EHCI”驱动程序设计成为实现新的高速型圆 USB 2.0 协议的芯片提供支持。”OHCI”驱动程序用来为非 PC 系统上的(以及带有 SiS 和 ALi 芯片组的 PC 主板上的)USB 芯片提供支持。”UHCI”驱动程序用来为大多数其它 PC 主板(包括 Intel 和 Via)上的 USB 实现提供支持。只需选择与希望启用的 USB 支持的类型对应的”?HCI”驱动程序即可。
启用了”USB support”和适当的”?HCI”USB 主控制器驱动程序后,使 USB 启动并运行只需再进行几个步骤。应该启用”Preliminary USB device filesystem”,SCSI计算机标准接口,因为通常我们的USB存储设备,模拟为SCSI硬盘而进行访问
一、关于内核
u-storage模块包括在内卜旦塌核但是由于U盘的初始化过程比执行/in/init慢,导致内核已经启动完成了,优盘还没有完成初始化工作,因此根文件系统没有加载,这时执行/in/init命令肯定不成功。所以要对系统内核初始化代码作修改如下:
/init/do_mounts.c
……
* Allow the user to distinguish beeen failed open
* and bad superblock on root device.
*/
– printk (“VFS: Cannot open root device “%s” or %s”,
+ printk (“VFS: Cannot open root device “%s” or %s,
retrying in 1 second.”, root_device_name, kdevname (ROOT_DEV));
– printk (“Please append a correct “root=” boot option”);
– panic(“VFS: Unable to mount root fs on %s”,
– kdevname(ROOT_DEV));
+ printk (“You may need to append a correct “root=” boot option”);
+ printk (“or wait for the root device to bee ready.”);
+
+ /* wait 1 second and try again,
+ * allowing time for hubs/devices to bee ready */
+ set_current_state(TASK_INTERRUPTIBLE);
+ schedule_timeout(HZ);
+ goto retry;
}
panic(“VFS: Unable to mount root fs on %s”, kdevname(ROOT_DEV));
out:
……
按照需要重新编译内核。
您也可以在启动内核时加载initrd.img文件到内存中,迟唤等待3秒使优盘完成初始化工作,再执行/in/init指令。
1、建立initrd.img文件
# mkdir -p /mnt/initrd
# cd /tmp
# mkinitrd /tmp/initrd.gz 2.4.20-u
2、解压initrd.img文件,修改启动脚本linuxrc
# gunzip initrd.gz
# mount -o loop /tmp/initrd /mnt/initrd
# cp /in/busybox /mnt/initrd/bin
# cd /mnt/initrd/bin
# ln -s busybox sleep
# vi /mnt/initrd/linuxrc
加入如下内容:
echo wait 3 seconds…..
/bin/sleep 3
3、重新生成initrd.img文件
由于缺省建立的initrd文件比较大(为4MB),为了加快优盘的启动,必须减小它。具体操作如下:
# mkdir -p /mnt/initrdu
# cd /tmp
# dd if =/dev/zero of= /tmp/initrdubs=1M count=1
# mke2fs -m 0 initrdu
# mount -o loop /tmp/initrdu/mnt/initrdu
# cp -a /mnt/initrd/* /mnt/initrdu
# umount /mnt/initrd
# umount /mnt/initrdu
# cd /tmp
# gzip -9 initrdu
# cp initrdu.gz /boot/initrd-2.4.20-u.img
二、建立优盘启动配置与目录结构
(/dev, /proc, /bin, /etc, /lib, /usr, /tmp, /var)
1、将优盘分成两个分区
留给Linux分区容量大小完全取决于安装哪些系统维护工具,结果如下:
# fdisk -l /dev/sda
Disk /dev/sda: 16 heads, 63 sectors, 126 cylinders
Units = cylinders of 1008 * 512 bytes
Device Boot Start End Blocks Id System
/dev/sda+ 6 FAT16
/dev/sda6 83 Linux
注意:如果需要使用优盘引导Windows 98,扇区大小必须设置为63个扇区,可以通过fdisk的x命令扩展修改heads、sectors和cylinders参数。更好还是利用U盘相应工具建立.
2、建立与生成ext2分区
# mke2fs -m 0 /dev/sda2
# mkdir -p /mnt/sda2
# mount /dev/sda2 /mnt/sda2
# cd /mnt/sda2
3、建立boot目录
将编译好的内核与initrd.img文件拷贝到boot目录、编译好的模块拷贝到lib/modules目录,以及将/boot/grub的文件拷贝到boot目录,编辑boot/grub/menu.lst文件,内容如下:
timeout 10
color 0x17 0x70
default 0
title Windows 98
rootnoverify (hd0,0)
makeactive
chainloader +1
title GNU/Linux Redhat 8.0 (2.4.20-u)
root (hd0,1)
kernel /boot/bzImage ro root=/dev/sda2
initrd /boot/ initrd.img 如果没有initrd.img,这句就不要了
安装grub,具体操作如下:
grub>; root (hd1,1)
grub>; setup (hd1)
4、建立bin目录
根据自工作的需要拷贝系统维护工具,如inod、fsck和mkdosfs等实用程序。
对于常用的工具,建议使用tinylogin tinylogin.busybox 或者busybox busybox,它们可以认您节约不省的空间.
另外,如果使用bash,还必须编辑与裁减/etc/termcap及如下文件:
/bin/bash
/etc/termcap
/usr/share/terminfo/l/linux
/usr/share/terminfo/k/klone+acs
/usr/share/terminfo/k/klone+color
/usr/share/terminfo/k/klone+sgr
5、建立dev proc usrin目录
使用cp -a命令拷贝常用的设备文件,包括console、tty1、tty2、tty3sda、sda1、sda2、hda、hdb和hda1等设备文件。如果您的内核使用Devfs, 只要建立这个目录即可.
建立proc usrin目录,你了可以ln –s binin建立in的连接.
6、建立lib目录
一定要注意使用ldd命令检查那些共享库文件,这些文件需要按照原来的路径拷贝到lib目录。
一般应有如下文件:
/lib:
–rwxr–xr–x 1 root rootNov 1 15:39 ld–2.0.7.so
lrwxrwxrwx 1 root root 11 Nov 1 15:39 ld–linux.so.2 –>;
ld–2.0.7.so
–rwxr–xr–x 1 root rootNov 1 15:39 libc–2.0.7.so
lrwxrwxrwx 1 root root 13 Nov 1 15:39 libc.so.6 –>;
libc–2.0.7.so
lrwxrwxrwx 1 root root 17 Nov 1 15:39 lib_err.so.2 –>;
lib_err.so.2.0
–rwxr–xr–x 1 root root 6209 Nov 1 15:39 lib_err.so.2.0
–rwxr–xr–x 1 root rootNov 1 15:39 libcrypt–2.0.7.so
lrwxrwxrwx 1 root root 17 Nov 1 15:39 libcrypt.so.1 –>;
libcrypt–2.0.7.so
–rwxr–xr–x 1 root rootNov 1 15:39 libdl–2.0.7.so
lrwxrwxrwx 1 root root 14 Nov 1 15:39 libdl.so.2 –>;
libdl–2.0.7.so
lrwxrwxrwx 1 root root 14 Nov 1 15:39 libpam.so.0 –>;
libpam.so.0.64
–rwxr–xr–x 1 root rootNov 1 15:39 libpam.so.0.64
lrwxrwxrwx 1 root root 19 Nov 1 15:39 libpam_misc.so.0 –>;
libpam_misc.so.0.64
–rwxr–xr–x 1 root root 7086 Nov 1 15:39 libpam_misc.so.0.64
–r–xr–xr–x 1 root rootNov 1 15:39 libproc.so.1.2.6
lrwxrwxrwx 1 root root 19 Nov 1 15:39 libtermcap.so.2 –>;
libtermcap.so.2.0.8
–rwxr–xr–x 1 root rootNov 1 15:39 libtermcap.so.2.0.8
–rwxr–xr–x 1 root rootNov 1 15:39 libutil–2.0.7.so
lrwxrwxrwx 1 root root 16 Nov 1 15:39 libutil.so.1 –>;
libutil–2.0.7.so
drwx––x––x 3 root root 1024 Nov 1 15:39 modules
drwx––x––x 2 root root 1024 Nov 1 15:39 security
/lib/modules:
drwx––x––x 4 root root 1024 Nov 1 15:39 2.0.35
/lib/modules/2.0.35:
drwx––x––x 2 root root 1024 Nov 1 15:39 block
drwx––x––x 2 root root 1024 Nov 1 15:39 cdrom
/lib/modules/2.0.35/block:
drwx–––––– 1 root root 7156 Nov 1 15:39 loop.o
/lib/modules/2.0.35/cdrom:
drwx–––––– 1 root rootNov 1 15:39 cdu31a.o
/lib/security:
–rwx––x––x 1 root root 8771 Nov 1 15:39 pam_permit.so
三、建立配置文件
1、编辑etc/init.d/rcS ?文件名决定于etc/inittab
内容如下:
#!/bin/sh
PATH=/in:/bin
export PATH
mount -n -t proc none /proc
umount /initrd
mount -n -o remount,rw /
mount -n -o remount,rw -t proc none /proc
ifconfig lo 127.0.0.1
hostname UBoot
2、编辑etc/fstab文件
内容如下:
/dev/sda2 / ext2 defaults 1 1
none /proc proc defaults 0 0
3、建立etc/inittab文件,如果用busybox生成的init这个文件可以不要。
id:2:initdefault:
si::sysinit:/etc/rcS
1:2345:respawn:/in/getty 9600 tty1
2:23:respawn:/in/getty 9600 tty2
4、建立nsswitch.conf文件
passwd: files
shadow: files
group: files
hosts: files
services: files
neorks: files
protocols: files
rpc: files
ethers: files
masks: files
bootparams: files
automount: files
aliases: files
group: files
publickey: files
5、建立/etc/pam.conf文件
OTHER auth optional /lib/security/pam_permit.so
OTHER account optional /lib/security/pam_permit.so
OTHER password optional /lib/security/pam_permit.so
OTHER session optional /lib/security/pam_permit.so
1、首先ping一下回环地址。
2、再ping一下本机ip查看自己本机的网络是否正确。
3、然枣陆尘后检查对方网络设置、防火墙、插件等等。
4、如果发现
丢包率
里有丢失
数据包
,可能是网络、网线的原因。
5、ping配置选项ping-c6192.168.80.100(表示ping6次之后断开)。
6、ping配置凳禅选项ping-s60000(悉拦更大65507)。
关于linux u回环程序的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
创新互联服务器托管拥有成都T3+级标准机房资源,具备完善的安防设施、三线及BGP网络接入带宽达10T,机柜接入千兆交换机,能够有效保证服务器托管业务安全、可靠、稳定、高效运行;创新互联专注于成都服务器托管租用十余年,得到成都等地区行业客户的一致认可。
当前题目:LinuxUSB回环程序:完美检测USB接口工作状态(linuxu回环程序)
当前URL:http://www.csdahua.cn/qtweb/news37/305887.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网