在系统加电以后自检时,就会完成对PCI总线的枚举,之后Linux对PCI配置空间的访问都是通过BIOS调用的形式进行,提供有这些功能和服务的BIOS就称之为PCI BIOS 。...需要注意的是Linux x86_64是不采用PCI BIOS访问PCI配置空间的,而是内核实现了直接访问PCI配置空间的函数(CONFIG_PCI_DIRECT)。...pcibios_init()的第一个功能是在内存中找到BIOS程序的代码(参考函数pci_find_bios),然后将调用BIOS例程的读写PCI配置空间的代码封装成函数赋值给pci_ops。...pci_ops里面的函数指针都是用来读写PCI配置空间的,把要读写的值和设备号告诉这些函数,在这些函数中调用了BIOS例程,并把这些值当作参数传给BIOS例程,BIOS再根据设备号和要读写的值来进行操作...所以Linux x86驱动程序中pci_read_config_byte()最终调用的是pci_bios_read_config_byte()。
PCI-X是PCI总线的扩展架构,PCI-X频率不像PCI那样固定,而是可以随着设备的变化而变化的。PCI-X采用64位PCI总线(PCI為32bit),可以支持66,100,133MHz这些频率。...与原来的PCI标准开发商不同的是,PCI的续集是由IBM等整机电脑厂商联合开发的。...PCI-X这样的口在一般的PC主板上看不到,多数都在服务器主板上.这种槽好像是PCI的加强型,槽口很长.它同时支持PCI-X和PCI两种插卡....交由PCI-SIG(PCI特殊兴趣组织)认证发布后才改名为“PCI-Express”。这个新标准将全面取代现行的PCI和AGP,最终实现总线标准的统一。...此外,较短的PCI-E卡可以插入较长的PCI-E插槽中使用,PCI-E接口还能够支持热拔插.
PCI总线常见于x86体系,本文默认面向的体系为x86,注意x86架构下IO与内存是独立编址的。 附: 本文默认读者熟悉Linux设备驱动模型,不熟悉的可以先阅读这两篇blog。...Linux驱动之I2C子系统剖析 Linux驱动之SPI子系统剖析 PCI寻址 PCI系统总体布局组织为树状,从CPU连接的Host Bridge引出PCI主桥,主桥连接的是PCI总线0,可以直接连接PCI...设备,或者再挂上PCI桥引出下一级PCI总线。...Linux内核启动时会从PCI设备的配置寄存器里读取内存/IO起始地址以及irq,并把这些信息赋值给struct pci_dev的相应成员来生成软件描述的PCI设备。...当linux系统启动时,会探测系统中的所有PCI设备,并为探测到的每个PCI设备做如下操作: 1.分配一个struct pci_dev结构体,用来表示相应的PCI设备 2.为这个结构体填充设备vendor
https://blog.csdn.net/xuzhina/article/details/43969499 有的时候,开发时需要用到设备的pci ID,如用dpdk来绑定某个网卡,需要用网卡的...pci ID。...下面有一些方法是可以获取pci ID的。 1.使用lspci命令。...可以看到以太网卡的PCI ID是02:01.0 但有时候在一些嵌入式的系统里,lspci命令并不是由pciutils提供,而是由其它软件包提供,或者是修改过,输出结果可能如下: ?...Intel(R) PRO/1000 Network Connection 也可以看到以太网卡的PCI ID是02:01.0 这种方法无论是在通用的发行版或是定制的嵌入式系统,都适用。
读写锁 与互斥量类似,但读写锁允许更高的并行性。其特性为:写独占,读共享。 读写锁状态: 一把读写锁具备三种状态: 1. 读模式下加锁状态 (读锁) 2. 写模式下加锁状态 (写锁) 3....不加锁状态 读写锁特性: 1. 读写锁是“写模式加锁”时, 解锁前,所有对该锁加锁的线程都会被阻塞。 2....那么读写锁会阻塞随后的读模式锁请求。优先满足写模式锁。读锁、写锁并行阻塞,写锁优先级高 读写锁也叫共享-独占锁。当读写锁以读模式锁住时,它是以共享模式锁住的;当它以写模式锁住时,它是以独占模式锁住的。...读写锁非常适合于对数据结构读的次数远大于写的情况。...函数 以读方式请求读写锁。
一、读写锁是什么?...读写锁其实还是一种锁,是给一段临界区代码加锁,但是此加锁是在进行写操作的时候才会互斥,而在进行读的时候是可以共享的进行访问临界区的 ps:读写锁本质上是一种自旋锁 二、为什么需要读写锁?...如果每次操作都给此段代码加锁,太浪费时间了而且也很浪费资源,降低程序的效率,因为读操作不会修改数据,只是做一些查询,所以在读的时候不用给此段代码加锁,可以共享的访问,只有涉及到写的时候,互斥的访问就好了 三、读写锁的行为...读写之间是互斥的—–>读的时候写阻塞,写的时候读阻塞,而且读和写在竞争锁的时候,写会优先得到锁 四、自旋锁&挂起等待是锁?...---->读和写在同时竞争锁的时候,写会优先的得到锁 互斥---->读的时候写阻塞,写的时候读阻塞 4.相关函数 (1)pthread_rwlock_init()—->初始化函数 功能:初始化读写锁
PCI、PCI-X、PCI-E区别 一、PCI总线 PCI总线标准是由PCISIG于1992年开发的,已经有超过8年的历史。 PCI的总带宽=33MHz×32BIT/8=133MB/S。...二、PCI-X总线 PCI-X是在增加了电源管理功能和热插拔技术的PCI V2.2版本的基础上,将PCI的总带宽由133MB/S增至1.066GB/s。...pci-x不是独立的,按照PCI总线的发展是:pci-pcix-pcie,他们都是为了提高PCI的传输速度的。...PCI-X是PCI总线的扩展架构,PCI-X频率不像PCI那样固定,而是可以随着设备的变化而变化的。PCI-X采用64位PCI总线,可以支 66,100,133MHz这些频率。...PCI-E也叫PCI-Express、PCIe,是由Intel提出来的,它是串行接口,不兼容PCI。 现在的趋势是PCI-E将替代PCI和PCI-X以及AGP,就像当年PCI替代ISA一样。
learn the auth of Linux.
一个简单实用且免费的网优规划工具,能实现如下功能: 1、站点PCI规划; 2、站点ZC根序列规划; 3、站点TAC规划; 4、区域站点数据重规划。...工具用的巧也可做为区域性的PCI重规划,对于零星的新开站点与PCI优化还是挺实用,工具界面如下: ?...PCI规划遵循模3原则,未做PCI保留功能,为避免PCI冲突与混淆,使用时“ZC/PCI复用距离”不宜给定太小,建议4-6Km(视站点覆盖场景而定)。...ZC/PCI复用距离与邻区规划距离超过10Km则以10Km进行计算。...TAC是根据PCI复用范围内站点使用的TAC占比最高那个,所以在区县交界的站点TAC规划结果可能会跨县,特别是多TAC边界。 素材需求 ?
使用hdparm工具或者time、dd命令测试硬盘读写性能 # hdparm for i in {0..9}; do hdparm -tT /dev/sdc; done root in summer
浅析 Linux 文件 IO 读写 Linux的文件IO子系统是Linux中最复杂的一个子系统(没有之一)。...读者可以参考以下这个图: image.png https://www.thomas-krenn.com/de/wikiDE/images/2/2d/Linux-storage-stack-diagram_v4.0...Linux的IO调度器称为evelator(电梯),因为Linus开始实现这个系统的时候,使用的就是电梯算法。
Window系统中查看一个文件是否为可执行文件,是通过扩展名(.exe、.bat 等),但在 Linux 系统中,文件是否能被执行,是通过看此文件是否具有 x 权限来决定的。...的用户访问权限应用到sakia作为所有者 将目录 /tmp/sco 这个目录的所有者和组改为sakia和组net chown -R sakia:net /tmp/sco chmod 修改文件和文件夹读写执行属性
一、PCI配置空间简介 PCI有三个相互独立的物理地址空间:设备存储器地址空间、I/O地址空间和配置空间。配置空间是PCI所特有的一个物理空间。...由于PCI支持设备即插即用,所以PCI设备不占用固定的内存地址空间或I/O地址空间,而是由操作系统决定其映射的基址。...系统加电时,BIOS检测PCI总线,确定所有连接在PCI总线上的设备以及它们的配置要求,并进行系统配置。所以,所有的PCI设备必须实现配置空间,从而能够实现参数的自动配置,实现真正的即插即用。...---- ---- linux下代码如下 #include #include #include #include #define...PCI_MAX_BUS 255 #define PCI_MAX_DEV 31 #define PCI_MAX_FUN 7 #define PCI_BASE_ADDR 0x80000000L #define
由于实在找不到MSI-X在x86上实现的教程或文档,只能分析Linux的PCI驱动程序了。希望能得到一些启发。...本文基于linux 5.17.5进行分析 __pci_enable_msix_range static int __pci_enable_msix_range(struct pci_dev *dev,...该函数原型如下: int pci_msi_setup_msi_irqs(struct pci_dev *dev, int nvec, int type) 该函数首先获取msi的domain,校验是否为继承的...(我还不明白这里是干啥意思的) 然后就会去调用pci_msi_legacy_setup_msi_irqs函数,去设置msix。...pci_msi_legacy_setup_msi_irqs 该函数的作用很简单:调用arch_setup_msi_irqs方法,去设置msi,然后通过pci_msi_setup_check_result
安装 Bash 如果你在使用 Linux,你可能已经有了 Bash。如果没有,你可以在你的软件仓库里找到它。...在 Windows 上,有几种方法可以体验 Bash,包括微软官方支持的 Windows Subsystem for Linux(WSL)。 安装 Bash 后,打开你最喜欢的文本编辑器并准备开始。
PCI,Peripheral Component Interconnect,在PC中广泛使用,几乎所有的主板产品上都带有这种插槽,主要用于连接显卡、网卡、声卡等外设 PCI总线是一种树型结构,并且独立于...PCI总线上可以挂接PCI设备和PCI桥,PCI总线上只允许有一个PCI主设备,其他的均为PCI从设备,而且读写操作只能在主从设备之间进行,从设备之间的数据交换需要通过主设备中转 VxWorks系统提供了一组命令来查看...PCI设备的信息,要想使用这些命令,在传统PCI驱动里提供了一个组件INCLUDE_PCI_CFGSHOW ?...两个网卡就是(PCI_CLASS_NETWORK_CTLRPCI_SUBCLASS_NET_ETHERNET<<8)=0x020000 ?...最后,pciConfigTopoShow()可以遍历PCI总线上的所有设备 ? 这正是: PCI设备好查看,不同版本有组件。 多个命令可调用,硬件信息来呈现。
生猛干货 从系统安装到程序员必备的Linux技能,还原真实工作场景,手把手带你实战演练 ?...IO速度 有时候我们在做维护的时候,总会遇到类似于IO特别高,但不能判定是IO瓶颈还是软件参数设置不当导致热盘的问题.这时候通常希望能知道磁盘的读写速度,来进行下一步的决策....下面是两种测试方法: (1)使用hdparm命令 这是一个是用来获取ATA/IDE硬盘的参数的命令,是由早期Linux IDE驱动的开发和维护人员 Mark Lord开发编写的( hdparm has..., with suggestions from many netfolk).该命令应该也是仅用于Linux系统,对于UNIX系统,ATA/IDE硬盘用的可能比较少,一般大型的系统都是使用磁盘阵列的....bs是每次读或写的大小,即一个块的大小,count是读写块的数量,相乘就是读写数据量大小。 数据量越大越准确,多次测试取平均值。
Advanced Technology 102f Toshiba America 1030 TMC Research 1031 Miro Computer Products 1032 Compaq (2nd PCI...Mentor ARC 10cd Advanced System Products 10ce Radius 10cf Citicorp TTI 10d0 Fujitsu Limited (2nd PCI...Sutherland 10de Nvidia 10df Emulex 10e0 Integrated Micro Solutions (IMS) 10e1 Tekram Technology (1st PCI...Advanced Techonoloy Labratories 1188 Shima Seiki Manufacturing 1189 Matsushita Electronics (2nd PCI...Mind Share 119b Omega Micro 119c Information Technology Institute 119d Bug Sapporo 119e Fujitsu (3th PCI
使用ifconfig()可以看到当前的Network信息,使用pciDeviceShow()可以看到PCI设备信息 那能不能把它们综合到一起?...在Vx69里写了个小程序,可以直接查看End设备的PCI位置以及Vendor ID和Device ID。售价50元 然后根据Vendor ID可以查看厂家,根据Device ID可以查看网卡类型
PCI-X 66 66 MHz 64 1 533 PCI-X 133 133 MHz 64 1 1066 PCI-X 266 133 MHz 64 2 2132 PCI-X 533 133 MHz 64...深入理解PCI空间与处理器空间的不同是理解和使用PCI的基础。 3.扩展性强。PCI总线具有很强的扩展性。...在PCI总线中,Root Bridge可以直接连出一条PCI总线,这条总线也是该Root bridge所管理的第一条PCI总线,该总线还可以通过PCI桥扩展出一系列PCI总线,并以Root bridge...在同一条PCI总线上的设备间可以直接通信,并不会影响其他PCI总线上设备间的数据通信。隶属于同一颗PCI总线树上的PCI设备,也可以直接通信,但是需要通过PCI桥进行数据转发。...所以PCIe“拍了拍”PCI,就把PCI“拍在沙滩上”了。
领取专属 10元无门槛券
手把手带您无忧上云