首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

计算机总线作用及分类详解

其它的还有 PCI、ISA、Thunderbolt 总线等。都是为了解决不同设备之间的通信。 试想,如果没有总线,新增了输入设备后,为了维持通信又得加一堆线路。 有了 I/O 总线后 ?...分类 片内总线 芯片内部的总线,寄存器与寄存器之间,寄存器与控制器、运算器之间。 高集成度芯片内部的信息传输线。 ? 系统总线 ?...数据总线 双向传输各个部件的数据信息,数据总线的位数(总线宽度)一般与CPU位数相同(32位、 64位) 地址总线 指定源数据或目的数据在内存中的地址,地址总线的位数与存储单元有关 地址总线位数=n,寻址范围...: 0~2^n 控制总线 发出各种控制信号的传输线,控制信号经由控制总线从一个组件发给另外一个组件,控制总线可监视不同组件之间的状态(就绪/未就绪)。...仲裁 总线上可能挂接多个设备,为了解决总线控制权的竞争问题,必须有总线仲裁部件,以某种规则裁决、分配总线的控制权。 多个主设备提出总线控制请求时,一般采用优先级或公平策略进行仲裁。

53710

Linux PCI和PCIe总线

3 Linux x86 PCIe调试 3.1 PCIe设备分类 – RC,BDF为00:00.0 – bridge就像hub,一般是个多功能的设备,传递数据需要仲裁,比较慢 – switch就像交换机...,PCIe规范中引入,比较快 – endpoint,x86主板上内置设备的总线号一般为0,而外挂EP的总线号一般从1开始 Figure 3-1 Type0 Header Figure 3-2 Type1...,所以总线编号是8位。...pcibios_init x86 BIOS专门提供了针对PCI总线的操作,这些操作里就包括了总线枚举的整个过程,Linux kernel中的宏CONFIG_PCI_BIOS。...在系统加电以后自检时,就会完成对PCI总线的枚举,之后Linux对PCI配置空间的访问都是通过BIOS调用的形式进行,提供有这些功能和服务的BIOS就称之为PCI BIOS 。

5.7K40
您找到你想要的搜索结果了吗?
是的
没有找到

【划重点】总线分类,这次你终于能分清啦!

另外就是采用总线结构便于部件和设备的扩充,尤其制定了统一的总线标准则容易使不同设备间实现互连。 总线分类 01 总线按功能和规范可分为五大类型 数据总线、地址总线、控制总线、扩展总线及局部总线。...数据总线、地址总线和控制总线也统称为系统总线,即通常意义上所说的总线。常见的数据总线为ISA、EISA、VESA、PCI等。...SPI、I2C是同步串行总线,RS232采用异步串行总线。 04 微机中总线一般有内部总线、系统总线和外部总线 内部总线是微机内部各外围芯片与处理器之间的总线,用于芯片一级的互连。...那么多分类, 今天先来聊聊内部总线、系统总线和外部总线咯。...该总线系统考虑到CPU与主存和Cache的直接相连,通常把这部分总线称为CPU总线或主总线,其他设备通过VL总线与CPU总线相连,所以VL总线被称为局部总线

1.5K20

Linux笔记(21)| platform总线驱动分析

//本文主要参考《野火Linux实战开发指南》 上次跟大家分享了设备模型的一些东西,包括总线、设备、驱动等的一些概念,还有他们之间的联系。...因为在Linux当中,对于I2C、SPI、USB这些常见类型的物理总线来说,Linux内核会自动创建与之相应的驱动总线,因此I2C设备、SPI设备、 USB设备自然是注册挂载在相应的总线上。...它们也就没有相应的物理总线,比如led、rtc时钟、蜂鸣器、按键等等,Linux内核将不会为它们创建相应的驱动总线。...为了使这部分设备的驱动开发也能够遵循设备驱动模型,Linux内核引入了一种虚拟的总线——平台总线(platform bus)。...> #include #include #include #include <linux/fs.h

2.2K40

Linux 总线、设备、驱动模型的探究

下面进入今天的话题——总线、设备和驱动模型的探究。 设想一个叫 GITCHAT 的网卡,它需要接在 CPU 的内部总线上,需要地址总线、数据总线和控制总线,以及中断 pin 脚等。 ?...没错,Linux 内核里就是运用了这种设计思想去对设备和驱动进行适配隔离的,只不过在内核里我们不叫做适配层,而取名为总线,意为通过这个总线去把驱动和对应的设备绑定一起,如图: ?...基于这种设计思想,Linux 把设备驱动分为了总线、设备和驱动三个实体,这三个实体在内核里的职责分别如下: ?...最底层是不同板子的板级文件代码,中间层是内核的总线,最上层是对应的驱动,现在描述板级的代码已经和驱动解耦了,这也是 Linux 设备驱动模型最早的实现机制,但随着时代的发展,就像是人类的贪婪促进了社会的进步一样...完美的 Linux 怎么会允许这样的事情存在,于是乎,设备树(DTS)就登向了历史舞台,下一篇内容将探讨设备树的实现原理和用法。 【部分内容整理于宋宝华老师课程】

6.4K41

19.Linux-USB总线驱动分析

是因为windows自带了USB总线驱动程序, USB总线驱动程序负责: 识别USB设备,给USB设备找到对应的驱动程序 新接入的USB设备的默认地址(编号)是0,在未分配新编号前,PC主机使用0地址和它通信...然后USB总线驱动程序都会给它分配一个地址(编号) PC机想访问USB总线上某个USB设备时,发出的命令都含有对应的地址(编号) USB是一种主从结构。...一个传输方向下 传输方向都是基于USB主机的立场说的, 比如:鼠标的数据是从鼠标传到PC机, 对应的端点称为"中断输入端点" 其中端点0是设备的默认控制端点, 既能输出也能输入,用于USB设备的识别过程 同样linux...其中usb_bus_type是一个全局变量, 它和我们之前学的platform平台总线相似,属于USB总线, 是Linux中bus的一种....如下图所示,每当创建一个USB设备,或者USB设备驱动时,USB总线都会调用match成员来匹配一次,使USB设备和USB设备驱动联系起来.

8.5K91

Linux内核平台总线设备驱动模型浅析

复习总线设备驱动模型,做了一点小笔记,大牛略过。 一、Linux系统的驱动框架的基础很大一部分是围绕着总线设备驱动模型展开的。...二、涉及3个重要结构体: struct bus_type:总线 struct device :设备 struct device_driver:驱动 三、结构体核心代码分析(2.6.38内核) structbus_type...{    const char       *name; // 总线名    struct bus_attribute   *bus_attrs; //总线属性文件,会显示在/sys/xxx中   ...,主要工作把设备(device)添加到总线       (bus_type)的klist_devices链表    return device_add(dev); } structdevice_driver...{    const char       *name;// 驱动名    struct bus_type       *bus;// 该驱动所属的总线    int (*probe) (struct

1.9K30

总线

总线是CPU与存储器和设备通信的机制,是计算机各部分之间传送数据、地址和控制信息的公共通道。 按照相对于CPU的位置来划分,总线可分为片内总线和片外总线。...片内总线用来连接CPU内部各主要功能部件,而片外总线则用作CPU与存储器和I/O接口之间进行信息交换的通道。如果按照功能和信号类型划分,总线可分为数据总线、地址总线和控制总线。...在描述一种系统总线时,我们通常会用到下面三个重要的参数: 总线宽度:又称为总线位宽,指的是总线能同时传送数据的位数,如16位总线就是具有16位数据传送能力。...总线频率:总线工作速度的一个重要参数,工作频率越高,速度越快。通常以MHz来表示。 总线带宽:又称总线的数据传送率,是指在一定时间内总线上可传送的数据总量,用每秒最大传送数据量来衡量。...总线带宽 = (总线宽度/8)*总线频率 带宽单位是MB/S;如总线宽度32位,频率66MHz,则总线带宽=(32/8)*66MHz = 264MB/S 如下图所示:一个微处理器系统可能含有多条总线,通常我们将高速设备连接到高速总线

1.3K90

详解CAN总线:高速CAN总线和低速CAN总线的特性

目录 1、高速CAN总线 1.1、电气特性 1.2、终端电阻 1.3、总线长度 1.4、布线电缆 1.5、设备数量 2、低速CAN总线 2.1、电气特性 2.2、终端电阻 2.3、总线长度 2.4、布线电缆...,并没有关于总线拓扑结构的说明):高速CAN总线和低速CAN总线,区别表如下所示: 本篇博文将详细介绍两者的特性和区别。...放置终端电阻位置如下所示: 1.3、总线长度 高速CAN总线总线长度最大为40m,当总线长度超过40m后,总线的速率会受到影响。...2、低速CAN总线 ISO 11898-3中定义了通信速率为10~125Kbps的低速开环CAN通信标准,当传输速率为40Kbps时,总线距离可达到1000米。...该标准允许在CAN总线连线失败时CAN总线通信得以继续进行。

2.9K20

详解CAN总线:什么是CAN总线

目录 1、CAN总线简介 2、CAN节点组成 3、CAN总线结构 4、CAN总线物理电气特性 ---- 在之前的博文中分享过一系列一文搞懂:SPI协议、I2C协议、PID算法、Modbus协议等文章,...总线协议的相关知识。...CAN总线协议(Controller Area Network),控制器局域网总线,是德国BOSCH(博世)公司研发的一种串行通讯协议总线,它可以使用双绞线来传输信号,是世界上应用最广泛的现场总线之一...: 符合OSI开放式通信系统参考模型; 两线式总线结构,电气信号为差分式; 多主控制,在总线空闲时,所有的单元都可开始发送消息,最先访问总线的单元可获得发送权;多个单元同时开始发送时,发送高优先级ID消息的单元可获得发送权...3、CAN总线结构 CAN总线是一种广播类型的总线,可支持线形拓扑、星形拓扑、树形拓扑和环形拓扑等。

2.1K30

AXI总线详解-总线、接口以及协议

总线、接口和协议,这三个词常常被联系在一起,但是我们心里要明白他们的区别。 总线是一组传输通道,是各种逻辑器件构成的传输数据的通道,一般由由数据线、地址线、控制线等构成。...再比如,只要百度一下串行和并行,就会出来很多类似“串行通信与并行通信”、“串行接口与并行接口”、“串行总线与并行总线”、“串行协议与并行协议”以及“串行传输与并行传输”等概念介绍,既有传输(通信)方式,...举个简单的例子,PCI总线说的是一组传输通道,而PCI接口是一种连接标准,两者之间的关系就是PCI接口的设备都要通过PCI总线来进行通信,而PCI总线上走的设备并不全是PCI接口的,像集成声卡,走的就是...PCI总线,但是没有走PCI接口。...OVER -END- 推荐阅读 AXI总线详解

2K10

自己实现事件总线-EventBus事件总线的使用

事件总线便可以用来解耦并重复利用应用中的逻辑。 事件总线带来的好处和引入的问题 好处比较明显,就是独立出一个发布订阅模块,调用者可以通过使用这个模块,屏蔽一些线程切换问题,简单地实现发布订阅功能。...示例代码 所以今天介绍一个简单的事件总线,它是事件发布订阅模式的实现,让我们能在领域驱动设计(DDD)中以事件的弱引用本质对我们的模块和领域边界很好的解耦设计。...事件总线 事件总线是被所有触发并处理事件的其他类共享的单例对象。要使用事件总线,首先应该获得它的一个引用。下面有两种方法来处理: 订阅事件 触发事件之前,应该先要定义该事件。...//获取领域模型的类型 var eventType = typeof(TEvent); //如果此领域类型在事件总线中已注册过...以上,就把事件总线介绍完了,完整的代码,请到github 上下载,这个只是EventBus 的简单实现,各位可以根据自己的实际场景和需求,优化修改。

1.4K10

详解CAN总线:CAN总线故障界定与管理

目录 1、错误状态的种类 2、故障界定规则 ---- 对汽车电子技术感兴趣的小伙伴请关注公众号:美男子玩编程,公众号优先推送最新技术博文,创作不易,请各位朋友多多点赞、收藏、关注支持~ CAN总线故障界定的目标是实现数据传输系统即使在节点发生故障的情况下也能维持很高的可用性...1、错误状态的种类 对故障界定而言,CAN节点根据错误计数结果的不同,可以处于下列3种状态之:主动错误状态、被动错误状态和总线关闭态。 1、主动错误状态 主动错误状态是可以正常参加总线通信的状态。...处于被动错误状态的单元虽能参加总线通信,但为不妨碍其它单元通信,接收时不能积极地发送错误通知。...处于被动错误状态的单元即使检测出错误,而其它处于主动错误状态的单元如果没发现错误,整个总线也被认为是没有错误的。 处于被动错误状态的单元检测出错误时,输出被动错误标志。...3、总线关闭态 总线关闭态是不能参加总线上通信的状态。信息的接收和发送均被禁止。 这些状态依靠发送错误计数和接收错误计数来管理,根据计数值决定进入何种状态。

1.1K30

总线-MBus_二总线与CAN对比

总线的定义 二总线是一种相对于四线系统(两根供电线路、两根通讯线路),将供电线与信号线合二为一,实现了信号和供电共用一个总线的技术。...二总线节省了施工和线缆成本,给现场施工和后期维护带来了极大的便利。在消防,仪表,传感器,工业控制等领域广泛的应用。在时间的维度上最早且典型二总线技术就是M-BUS。...设总线上只有一个从站,那么总线稳定电流= Imark,则Ispace=Imark+(1120)mA,表示逻辑0.即从站从总线上吃掉1120mA电流发送Bit0。...M-Bus总线为单工,异步的通信这是因为如上图所示,从站向主站发送数据的时候,会引起总线上的电压被拉低。所以当从站发送数据的时候,主站无法发送数据。...根据MBus总线物理层的相关定义,TSS721A从站接口芯片具备检测总线电压(接收数据)和调制总线电流(发送数据)的功能。

1.5K10

CAN总线(一)

现在每一辆汽车上都装有CAN总线。 一个典型的CAN应用场景: ? CAN总线标准 CAN总线标准只规定了物理层和数据链路层,需要用户自定义应用层。不同的CAN标准仅物理层不同。 ?...多个节点连接,只要有一个为低电平,总线就为低电平,只有所有节点输出高电平时,才为高电平。所谓"线与"。 CAN总线有5个连续相同位后,就插入一个相反位,产生跳变沿,用于同步。从而消除累积误差。...CAN总线,终端电阻的接法: ?...仲裁段 CAN总线是如何解决多点竞争的问题? 由仲裁段给出答案。 CAN总线控制器在发送数据的同时监控总线电平,如果电平不同,则停止发送并做其他处理。...CAN是可靠性很高的总线,但是它也有五种错误。

86720

Linux 内核】CPU 分类与状态 ( CPU 处理器分类 | 根据物理属性分类 SMT、MC、SoC | Linux 内核中 CPU 分类 | Linux 内核源码中的 CPU 状态源码 )

文章目录 一、CPU 处理器分类 1、根据物理属性分类 ( SMT、MC、SoC ) 2、Linux 内核中 CPU 分类 二、Linux 内核源码中的 CPU 状态源码 一、CPU 处理器分类 --...-- 1、根据物理属性分类 ( SMT、MC、SoC ) 根据 CPU 的物理属性 , 可以将 CPU 分为如下几类 : SMT : 全称 " Simultaneous Multithreading "...资源 , 共享 L1 Cache 缓存 ; MC : Multicore 多核 , 每个物理核心 独享一个 L1 Cache 缓存 ; SoC : System on Chip , 系统级芯片 ; 2、Linux...内核中 CPU 分类 Linux 内核中 , 对 CPU 处理器的分类 : CONFIG_SCHED_SMT : 对应 SMT 芯片 , " 超线程 " , 一个物理核心 , 可以有 2 个执行线程...内核源码中的 CPU 状态源码 ---- Linux 内核中 , 通过 bitmap 管理 CPU 处理器 , 并且在 Linux 源码中的 linux-5.6.18\include\linux\cpumask.h

3.8K61

I2C总线架构 之 总线驱动

这种做法完全不适应Linux的通用性的设计理念,对于Linux来讲:同样的事情我只做一遍,向外提供接口,不管你是什么IIC设备挂载那条IIC总线上,都可以用。...因此,这就需要Linux在代码架构上有非常严谨的模块化设计。 架构设计 在Linux设计中,将I2C代码框架分为三个部分:I2C总线、I2C核心、I2C驱动。...「I2C总线驱动(i2c adapter):」 根据平台定制的i2c驱动,其中包含i2c传输的算法设计。...本篇主要对IIC总线驱动的总结。 i2c总线结构体 Linux在分层中,必不可少的将每一层模块封装成一个结构体,然后将结构体作为一个与外接交互的桥梁。...platform虚拟总线架构,其中包括一些platform常规注册流程,主要关注probe中的代码。

1.4K30
领券