2,用示波器抓取mdc和mdio波形,读PHY寄存器没有数据响应。
(2)控制寄存器 一般的PHY中地址为0x00的寄存器可用于芯片的复位以及其他功能的控制。本例程中用到了其中的bit9,用于使芯片重新进行自协商。寄存器描述如下图所示。 ?...接口mdc时钟信号 mdio inout MDIO接口mdio双向数据信号 (三)模块原理 (1)mdio_top模块 本模块主要完成PHY芯片状态监控和配置,并控制子模块mdio_control完成...在本例程中,写入的为1.2.1节中所述的地址为0x00的控制寄存器的bit9,使PHY芯片重新进行自协商,重新建立以太网连接。...(2)mdio_control模块 本模块在mdio_top模块的控制下,完成MDIO接口协议的实现,以及PHY芯片相应寄存器的读写操作。 模块中,通过ODDR实现PHY芯片mdc时钟的输出。...通过IOBUF实现mdio双向端口,如下图。其中mdio_direction用于控制mdio接口的方向。 ? 本模块的工作状态机如下图所示。 ?
MDIO接口包括两根信号线:MDC和MDIO,通过它,MAC层芯片(或其它控制芯片)可以访问物理层芯片的寄存器(前面100M物理层芯片中介绍的寄存器组,但不仅限于100M物理层芯片,10M物理层芯片也可以拥有这些寄存器...),并通过这些寄存器来对物理层芯片进行控制和管理。...MDIO是一根双向的数据线。用来传送MAC层的控制信息和物理层的状态信息。MDIO数据与MDC时钟同步,在MDC上升沿有效。...TA:状态转换域,若为读操作,则第一比特时MDIO为高阻态,第二比特时由物理层芯片使MDIO置“0”。若为写操作,则MDIO仍由MAC层芯片控制,其连续输出“10”两个比特。...当门电路的输出上拉管导通而下拉管截止时,输出为高电平;反之就是低电平;如上拉管和下拉管都截止时,输出端就相当于浮空(没有电流流动),其电平随外部电平高低而定,即该门电路放弃对输出端电路的控制 。
答案是可以的 如果phy芯片没有,那么可以直接通过两个mac连接进行通信,之所以需要mac 、phy、变压器的目的是为了转换数据类型适配所以的网线,但是在一些电路上,没必要加这么多东西 比如搭载 Linux...MDC信号由STA控制,MDIO信号根据通信方式的不同可以由STA或者PHY接管控制。如图通常MDIO会接一个电阻上拉至接口电源。...换个话说 不连接也可以使得网络畅通,因为网络的数据传输时靠RGMII不是靠MDIO,MDIO的作用仅仅只是用来查看一些状态和功能,还有简单的控制,而这些简单的控制是完全可以有网卡芯片内置去写死,arm层只要和网卡的写的一直就可以通讯...但是为什么很多时候需要通过mdio来进行读写控制,这个只是在网络通讯正常后的升级优化,用来方便查看状态,就像写了个前端网页来看后台数据。 ...以上内容是海翎光电的小编看了大量的参考文献和一步步的实践总结的经验,通过实践,把每一层都走一遍,把变压器去掉,把phy去掉,linux系统的网卡函数看了一遍,phy芯片的手册有看了很多。
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 作业控制 启动,...停止,无条件终止,以及恢复作业的这些功能统称为作业控制。...aoi ~]# jobs [1]+ Stopped sh ss [2]- Running sh ss > sss & $$用来显示linux
进程4要素 要有一段程序供该进程运行 进程专用的系统堆栈空间 进程控制块(PCB),具体实现是task_struct结构 有独立的存储空间 Linux系统中所有的进程是相互联系的,除了初始化进程外,所有进程都有一个父进程...Linux中所有的进程都是由一个进程号为1的init进程衍生而来的。...(守护进程):Linux启动时启动的进程,并在后台运行 进程控制块 在Linux中,每个进程在创建时都会被分配一个数据结构,称为进程控制块(PCB, Process Control Block),描述进程的运动变化过程...通过ps命令可以查看系统中目前有多少进程正常运行 通过ps-aux命令可以查看每个进程的详细信息 进程控制的相关函数 fork()函数 系统调用fork()函数派生一个进程,函数原型为: #include...参考:《精通Linux C编程》- 程国钢
进程控制 fork函数 进程终止 退出码 常见的退出方式 进程等待 什么是进程等待,为什么要进程等待 阻塞与非阻塞 进程替换 替换原理 替换函数 执行系统命令 执行自己写的程序 模拟实现简易的shell...但是如果让我们自己去求信号和退出码很麻烦,所以Linux提供了一些操作的宏,重点说两个: WIFEXITED(status): 若为正常终止子进程返回的状态,则为真。...是先调用exec函数,因为它的作用上面说了,是将程序加载到内存中,Linux中,它就是加载器。
但是,对于获得子进程的退出结果,我们可以不采用位操作进行,Linux提供了对应操作的宏 WIFEXITED(status): 若为正常终止子进程返回的状态,则为真。...execl系列函数将程序加载到内存中,所以Linux的execl接口是加载器,所以是先加载后执行,main也是函数也要被调用,通过execl/系统传参给main 程序替换中execve是系统调用,其他都是封装
今天,我们要开始学习新的内容了--->进程控制,进程控制涉及到操作系统如果管理和控制运行在计算机系统内的进程。...我们将从fork函数,Linux进程退出,Linux进程等待,Linux进程替换等方面学习。那么接下来我们就开始敲黑板了!! fork函数 话不多说,上码!!...printf("我是父进程,wer:%d,&wer:%p\n", wer, &wer); sleep(3); } } return 1; } 在Linux
要使用多线程,因为Linux没有给一般用户直接提供操作线程的接口,我们使用的接口,都是系统工程师封装打包成原生线程库中的。那么就需要用到原生线程库。...,status: %d\n",ret,(int)status); return 0; } LPW的解释 在使用ps -aL查看线程情况时,LWP为内核LWP,我们最好不要叫它线程ID,因为在Linux...也需要拥有描述线程的用户控制块!但是在虚拟地址空间中的栈结构,不可能会分成很多份给每一个线程的,它是属于主线程和进程的! 每一个新线程所拥有的栈结构等等,其实都是由原生线程库提供的!...每一个线程跟每一个库提供的线程栈和线程局部存储等组成的用户控制块都是一一对应的,是以1:1的比例对对应着!...那么如何区找到需要找到的线程,就需要用到一个地址去找,并且每一个描述线程的用户控制块都会保存着每一个线程对应的PWD!这个地址就是每一个用户控制块的地址!
进程控制 一、进程创建 1. fork 函数创建子进程 在 Linux 中 fork 函数是非常重要的函数,它从已存在进程中创建一个新进程。新进程为子进程,而原进程为父进程。...当进程调用 fork,控制转移到内核中的 fork 代码后,内核应该做: 分配新的内存块(pcb)和内核数据结构(进程地址空间、页表等)给子进程 将父进程部分数据结构内容拷贝至子进程 将子进程添加到系统进程列表当中...但是我们的 Linux 中并不使用系统提供的接口获取退出码的退出原因描述,而是使用自定义的退出原因描述。...但是我们通过位运算得到的退出信息可读性不是很好,所以 Linux 也为我们提供了两个接口: WIFEXITED(status): 若为正常终止子进程返回的状态,则为真。
若父子进程数据都不修改,则父子进程指向同一个物理地址, 若子进程数据修改,则拷贝一个物理空间,将新的地址填到子进程对应的页表中,使子进程重新映射,访问到新的空...
网络访问控制:netfilter模块,可以对数据进行允许、丢弃、修改操作 数据包分类:源IP地址、目标IP地址、使用接口、使用协议、端口号、连接状态 过滤点:input、forward、output...iptables通过规则对数据进行访问控制 一个规则使用一行配置 规则按顺序排列 当收到、发出、转发数据包时,使用规则对数据包进行匹配,按规则顺序进行逐条匹配 数据包按照第一个匹配上的规则执行相关动作
在linux中fork函数时非常重要的函数,它从已存在进程中创建一个新进程。新进程为子进程,而原进程为父进程。...代码和数据加载到内存的操作,其实就是操作系统调用了exec*函数完成的,所以在Linux的系统中,exec*是加载器。exec*函数的功能就是将程序加载到内存嘛,这是谈的第一点。
4、shell 的最终实现 一、进程创建 1、再谈 fork 函数 我们在 进程概念与进程状态 中对 fork 函数进行了初步的介绍与使用,在这里我们来详细的学习一下 fork 函数;fork 是 Linux...cnt++; } return 0; } 注:运行上面这个程序可能导致服务器或者虚拟机直接挂掉,虚拟机直接 shutdown 关机重启即可;服务器则需要到对应的服务器控制台进行重启...一般来说: 0表示进程运行结果正确; 非0表示运行结果错误; 对于非0来说,不同的数字有又对应着不同的错误,我们可以自己设定不同退出码所对应的错误信息,也可以使用系统提供的退出码映射关系: 在 Linux...指令 “ls” 为例,我们知道,ls 是Linux中 “/usr/bin” 目录下的一个可执行程序,且该程序处于PATH环境变量中,那么如果我们要替换此程序,exec 函数的第一个参数如下: execl...mybin", NULL, environ); //传递环境变量 ---- 五、实现一个简易的 shell 1、shell 的初步实现 在学习了进程创建、进程终止、进程等待以及进程程序替换系列进程控制相关知识后
内核资料直通车:最新Linux内核源码资料文档+视频资料学习直通车:Linux内核源码/内存调优/文件系统/进程管理/设备驱动/网络协议栈2.1.1 MII接口MII(Media Independent...MII接口主要包括以下三个部分:从MAC层到PHY层的发送数据接口从PHY层到MAC层的接收数据接口从MAC层和PHY层之间寄存器控制和信息获取的MDIO接口首先来看看MII的MAC层定义接口:MII...MDC/MDIO基本特性:两线制:MDC(时钟线)和MDIO(数据线)。...因此 Linux 内核有通用 PHY 驱动,按道理来讲,不管你使用的是哪个厂家的 PHY 芯片,都可以使用 Linux 的这个通用 PHY 驱动来验证网络工作是否正常。...这些多出来的几次器可以实现厂商特有的一些技术,因此在Linux内核里面可以看到很多具体的PHY芯片驱动源码。四,总结MAC 就是以太网控制器,属于OSI的数字链路层。
前言:前面了解完前面的Linux进程基础概念后,我们算是解决了Linux进程中的一大麻烦,现在我们准备更深入的了解Linux进程——Linux进程控制!...我们主要介绍的Linux进程控制内容包括:进程终止,进程等待与替换,进程程序替换! 本篇主要内容: 重识进程创建 进程退出场景 错误码和退出码 1....#include pid_t fork(void); // 返回值:自进程中返回0,父进程返回子进程id,出错返回-1 进程调用fork,当控制转移到内核中的fork代码后,...exit终止进程的时候,不会自动刷新缓冲区 总结 进程终止相对于其他的进程控制来说,是很好理解的。我们主要介绍了进程终止,在明白错误码和退出码之后,相信能理解父进程是怎么得到子进程信息的。
前言:接着前面进程终止,话不多说我们进入Linux进程等待的学习,如果你还不了解进程终止建议先了解: Linux进程终止 本篇主要内容: 什么是进程等待 为什么要进行进程等待 如何进程等待...这个就是因为进程具有独立性,父进程无法直接获得子进程的退出信息 总结: 进程等待确实非常有用,它既可以回收僵尸进程,避免造成内存泄漏,也能让父进程能够获取到子进程的退出信息,进程等待我们就先了解这么多,进程控制马上就到了我们的最后一步
领取专属 10元无门槛券
手把手带您无忧上云