首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    汇编调试方式之:通过串口转义输出寄存器的值

    前两天在调试DragonOS的riscv引导代码的时候,想在真机上获取寄存器的值,就找到了这篇帖子,非常有用,就把里面的代码提取出来,在此记录。...因为在汇编里面难以对字符串进行格式化操作,因此可以考虑把寄存器的值转义一下,然后输出到串口,再使用一个C程序把它转义回来。...方法如下: 编码函数 首先在汇编里面定义这样一个函数: // 要打的值输入到a0 __do_show_val: // todo: 为了保护寄存器,这里应当添加压栈操作, // 把函数使用到的寄存器都保存一下...,就把要打印的寄存器的值,移动到a0,然后call这个函数即可。.../show Enter:PAAAIFPDAAAAAAAA 000000003F58000F Enter: 所以我们可以看到这个寄存器的值就是“3F58000F“。

    22510

    RGMII接口调试使用VIO读取PHY寄存器值

    比如RGMII接口,最重要的是看在哪里去做的时钟和数据偏移。这时,常常需要使用VIO去读取PHY里面对应寄存器的值,看是否工作在正常RGMII接口时序模式。 测试场景 测试拓扑图如下 ?...经验总结:遇到RGMII接口调试时,最关键的是要查看PHY芯片的型号,查阅PHY芯片手册,通过MDIO读取PHY芯片寄存器的值,看RGMII接口上数据和时钟是否偏移2ns,再决定FPGA对应管脚约束是否进行偏移...具体的测试步骤为:通过VIO配置MDIO管理模块PHY地址、寄存器地址,然后选择读操作读取某一PHY芯片的寄存器的值,结合PHY的工作状态,判断该寄存器是否被正确读取。...mdc_o) ); //------------------------------------------------------------------- 通过VIO和MDIO读取相应寄存器的值...,如图10所示,读取到的值为1076,换算成2进值为0000_0100_0011_0100,对应的工作模式为图8所示的Transmit clock internally delayed,即 add delay

    4.7K21

    振弦采集模块配置工具VMTool生成寄存器值

    河北稳控科技振弦采集模块配置工具VMTool生成寄存器值图片生成寄存器值VMXXX 有很多按位使用的寄存器, 使用 VMTool 工具可进行方便的设置,当需要知道寄存器的实际值时,可通过以下两种方法获取...(保持【 自动读取】 复选框为非选中状态)( 1) 振弦模块与 VMTool 工具连接时在界面上进行参数设置;点击【 写入模块参数】 按钮,将当前界面显示的参数写入模块;点击【 读取模块参数】 按钮,模块的寄存器值会自动更新到...MODBUS 显示区的表格内。...( 2) 振弦模块未与 VMTool 工具连接时在界面上进行参数设置;双击【参数设置】 区的标题“ 参数设置” 文字;当前界面显示的参数自动更新到 MODBUS 显示区的表格内;图片VMTool 扩展功能双击主界面右侧扩展工具条可实现扩展功能区的显示与隐藏切换

    43030

    Linux下开发stm32 ③ | 寄存器工程开发

    先来回顾一下前两篇 Linux下开发stm32(一) | 使用gcc-arm-none-eabi工具链编译 Linux下开发stm32(二) | 使用openocd下载与调试 前两篇我们介绍了如何创建一个空的裸机工程...main文件),并编译工程生成elf文件,然后将其转为bin格式或hex格式,使用openocd下载,最后编写了一个makefile雏形,并成功点亮了一个LED~ 但是这个LED我们是通过指针直接操作寄存器地址来完成的...,接下来,我们在此基础上,引入stm32头文件,其中包含了寄存器的宏定义,也就是使用寄存器进行开发~ 1.创建寄存器工程 首先将上一节中创建的裸机工程00-template-reg复制一份出来,改名为01...将其中空的stm32f10x.h文件删掉,从固件库中复制一份,然后因为头文件中使用了core_cm3.h和system_stm32f10x.h中的一些定义,包含了这两个头文件,所以将这两个文件也复制过来...,接下来开始编译~ 2.编译&下载寄存器工程 编译寄存器工程的重点就在于C头文件和C源文件,启动文件的编译和链接都和之前一样。

    1.3K30

    寄存器的相关知识

    寄存器 寄存器是CPU中的存储单元,用于存储指令和数据。寄存器具有高速存储和快速访问的特点,能够提高CPU的运算速度。...寄存器通常都是以他们可以保存的位元数量来估量,例如一个“8位元寄存器”或“32位元寄存器”。寄存器拥有非常高的读写速度,所以在寄存器之间的数据传送非常快。...指针寄存器主要用于保存内存单元的地址,用于间接寻址。变址寄存器主要用于保存要修改的内存单元的地址,用于间接寻址。 专用寄存器是专门用于特定操作的寄存器,如指令指针寄存器、标志寄存器等。...指令指针寄存器用于保存下一条要执行的指令的地址,标志寄存器用于保存运算结果的状态信息。 特殊寄存器是用于特定硬件功能的寄存器,如段寄存器、控制寄存器等。...一些常用寄存器的名字及其功能 寄存器的功能取决于其所在的硬件设备和上下文环境。 EBX基址寄存器:常用于访问内存数据,作为内存数据的指针。 ECX计数器寄存器:常用于字符串和循环操作中的计数。

    14310

    汇编寄存器的规则

    但是,一旦函数序言(准备堆栈和寄存器的函数的开始部分)完成执行,这些寄存器中的值就可能改变。生成的程序集可能会覆盖存储在这些寄存器中的值,或者在代码不再需要这些引用时丢弃这些引用。...需要注意的是,该应用程序不会实时的显示寄存器的值; 它只能在特定的函数调用期间显示寄存器的值。...这意味着您不会看到这些寄存器的值有太多更改,因为在调用获取寄存器值的函数时它们可能具有相同(或相似)的值。...幸运的是,只有一个指定的寄存器用于返回值:RAX。...了解 RAX 中的返回值非常重要,因为它将构成您将在后面的部分中编写的调试脚本的基础。 # 改变寄存器值 为了巩固您对寄存器的理解,您将在一个已编译的应用程序中修改寄存器。

    2.6K50

    8086CPU的寄存器

    在进行堆栈操作时,SP的值随着栈顶的变化而自动改变,但始终指向栈顶位置;BP是访问堆栈时的基址寄存器,存放堆栈中某一存储单元的偏移地址,使用BP是为了访问堆栈区内任意位置的存储单元。...PF(奇偶标志位) 同于反映运算结果的奇偶性,即第八位中含有“1”的个数。如果“1”的个数为偶数,则PF的值为1,否则为0。利用PF可根据奇偶校验检查,或产生奇偶校验位。...如果运算结果超过当前运算位数所能表示的范围,则称为溢出,OF的值被置为1,否则,OF的值被清为0.具体来说,就是当有符号数字节运算的结果超出了-128~ +127范围,或者字运算时的结果超出了-32768...8086指令系统中提供了专门改变IF值的指令。 DF(方向标志位) 用来控制串操作指令中地址指针的变化方向。...单步执行方式主要用于程序的调试,指令系统中没有提供专门的指令来改变TF的值,但用户可以通过编程办法来改变其值。 后续 如果想了解更多物联网、智能家居项目知识,可以关注我的项目实战专栏。

    94710

    Linux Shell函数返回值

    Shell函数返回值,一般有3种方式:return,argv,echo 1) return 语句 shell函数的返回值,可以和其他语言的返回值一样,通过return语句返回。 示例: #!...获取函数的返回值通过调用函数,或者最后执行的值获得。 另外,可以直接用函数的返回值用作if的判断。 注意:return只能用来返回整数值,且和c的区别是返回为正确,其他的值为错误。...中,对全局变量的修改也无济于事,全局变量的值根本就没有改变。...因此不存在上面提到的由于管道导致返回值失效的情况。 在外边只需要获取函数的返回值即可。 示例: #!...参考推荐: Shell函数返回值 Linux 之 shell 比较运算符(推荐) Linux Shell学习简单小结(推荐) SHELL学习笔记----IF条件判断,判断条件

    9.2K20

    寄存器,移位寄存器的电路原理以及verilog代码实现「建议收藏」

    寄存器:用以存放二进制代码的电路,下图为由维特阻塞D触发器组成的4位数码寄存器: 逻辑功能分析: 1.异步端CR置0时,输出置0; 2.同步并行置数:D0~D3为4个输入代码,当CP上升沿到达时,D0...2.移位寄存器:具有存放数码和使数码逐位右移或左移的电路称为移位寄存器。 移位寄存器按照不同的分类方法可以分为不同的类型。...如果按照移位寄存器的移位方向来进行分类, 可以分为左移移位寄存器、移位寄存器和双向移位寄存器等;如果按照工作方式来分类,可以分为串入/串出移位寄存器、串入/并出移位寄存器和并入/串出移位寄存器等。...begin q<=4'b0000; //q 置 置 0 end else begin if(cnt>0) // 判断 cnt 是否大于 0 begin q[3:1]的值向左移...1 位 end else if(cnt==2'b00) // 判断 cnt 是否为 0 begin q的值赋予 q end dout<=q[3]; //把 把

    1.5K20

    linux recv返回值,recv recvfrom

    ,在linux下面这里的int s, 其实代表的是文件描述符。...在成功接受到数据后,返回值都是实际接受的字节数; 套接字关闭时,返回都为0; 接受出错时,windows下面都返回SOCKET_ERROR , linux下面都返回-1, 其实你要是感兴趣可以查看SOCKET_ERROR...定义,它的值也是-1; 关于这里的“套接字关闭”需要注意,2个函数在用在流式套接字和数据报套接字时,套接字表示的含义不一样,前者表示客户端套接字,而后者表示的是自己的套接字。...如果套接字为阻塞的,在系统缓冲中没有数据的情况下,都将阻塞;如果套接字为非阻塞的,在系统缓冲中没有数据的情况下,都将立即返回,返回值在linux 下为-1, errno被设置为EWOULDBLOCK,在...如果内核缓冲区有1500个字节,那么 szRecvBuf将被填充256个字节,返回值就是256. 如 果是数据报套接字,在内核缓冲区中的数据小于要求长度(这里是256)的情况下,和流式套接字结果一样。

    2.9K20
    领券