0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

sparc体系架构的窗口寄存器的深入理解

嵌入式IoT 来源:嵌入式IoT 作者:嵌入式IoT 2021-01-07 10:39 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

sparc体系架构的窗口寄存器的深入理解

1.概述

2.窗口寄存器的特性

3.程序的设计

4.sparc设计对于嵌入式编程的优劣

1.概述

sparc这种架构有着特殊的窗口寄存器,使用sparc芯片,一定会对这种窗口寄存器产生疑惑,然而这种硬件特性却让软件设计有着更加独特的方式。下面来描述一下sparc架构中这种串口寄存器的特性以及编程模型。

2394659a-5074-11eb-8b86-12bb97331649.png

采用窗口寄存器,可以减少函数调用过程中返回时间,因为通过硬件进行压栈操作时,可以减少指令条数以及减少访问存储器的次数。

窗口寄存器的本质是每当执行一次函数调用过程时,寄存器窗口会自动的指向下一个窗口,当子程序返回时,也不需要额外的出栈操作,只是将窗口偏移到上个寄存器即可。

而两个相邻的窗口则有重叠部分,可以对两个父子函数之间进行参数传递,这样大大的提高了访问的效率以及寄存器的专一性。

2.窗口寄存器的特性

当在实际的程序中使用时,往往会涉及到多个函数的嵌套,这些在复杂程序设计上非常的普遍,业务逻辑的增加会显著的增加函数调用的深度。如果函数调用超过了这些8个窗口,sparc架构又是该如何处理呢?

在sparc的架构中,CWP(当前窗口指针)是PSR(程序状态寄存器)的一部分,在某一固定的时刻,处理器中都只会有32个整数寄存器可以被使用。这32个寄存器为8个全局寄存器、8个返回结果寄存器、8个局部寄存器、8个输入寄存器。CWP通常会因SAVE指令(SAVE指令一般在过程调用时使用,用来开辟新的栈帧并切换寄存器窗口)而减一,因RESTORE指令(在从过程中返回前切换回调用者的寄存器窗口)而加一,陷阱事件(中断,异常或TRAP指令)和RETT指令(从陷阱中返回)也会改变CWP,不过函数调用比陷阱更为常见。

23bbd74c-5074-11eb-8b86-12bb97331649.png

窗口无效掩码(WIM) WIM指示了哪个窗口是无效的,无效的意思是该窗口保存了调用者的信息所以不可再使用,上图中,WIM指向w7,而CWP指向w0,所以现在如果执行一条SAVE指令,则会触发窗口溢出陷阱,反之,如果CWP指向w0且又执行了一条RESTORE指令,则会触发窗口下溢陷阱。

所谓的窗口下溢则是说当前窗口不够用了,需要将已经满了的窗口寄存器的数据压入到栈上,也就是内存中,压入后的窗口寄存器又可以重新利用起来了,而上个满了的窗口寄存器则存在内存中了。当函数返回到窗口无效寄存器时,则发生上溢陷阱,该陷阱中会执行出栈的操作,从而将寄存器进行恢复。

3.程序的设计

对于C语言来说,并不用关注架构的不同带来的差异性,而对于汇编来说,则设计却是完全的不同。GCC已经处理好了C转换成汇编的逻辑。

23e62858-5074-11eb-8b86-12bb97331649.png

每个save指令都是在被调用的函数的第一条指令处开始执行。而SAVE的指令与ADD的指令相同,其功能是可以将sparcCWP减一。让CWP-1窗口成为新的当前的窗口。

当函数执行完成后,则执行restore指令,让窗口指令加一。窗口就回归原位了。

4.sparc设计对于嵌入式编程的优劣

对于嵌入式来说,如果只设计可控的程序,逻辑设计上尽可能的单一可控,并且最好函数的嵌套深度不应该超过8个,最好不发生上溢或者下溢操作。这样不用访问存储器,并且底层的指令很少,对于程序的执行效率很有保障。有上溢或者下溢,一次性就需要压栈或者出栈操作,使得其程序的执行效率不在那么高效。

而对于rtos来说,设计上也稍微复杂了一些,需要不仅需要判断当前窗口的溢出情况,还需要保存窗口寄存器的栈,这样对于系统上下文的线程栈需要的空间消耗是非常大的。目前也没有想到合适方式去减少栈的消耗,而且在rtos上,sparc架构所占的优势并不是很明显,以上仅仅是我对这种架构在嵌入式上使用的一些看法。

总结起来,sparc架构的好处是由于有了窗口寄存器模型,如果程序设计的优秀简单,这个是非常好的,效率也可以非常高,简洁的寄存器、简洁的控制状态,需要编程人员要有很高的水平。缺点就是不考虑sparc架构的编程方式,将会使得程序的效率非常的低下,sparc芯片的使用也变得十分的困难。

责任编辑:xj

原文标题:sparc体系架构的窗口寄存器的深入理解

文章出处:【微信公众号:嵌入式IoT】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5589

    浏览量

    129064
  • 窗口
    +关注

    关注

    0

    文章

    66

    浏览量

    11233
  • SPARC
    +关注

    关注

    0

    文章

    16

    浏览量

    10142

原文标题:sparc体系架构的窗口寄存器的深入理解

文章出处:【微信号:Embeded_IoT,微信公众号:嵌入式IoT】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    【NCS随笔】nRF54L15使用UICR寄存器保存数据

    nRF54L15使用UICR寄存器保存数据 本文章主要是讲解如何使用nRF54L15的UICR寄存器保存一些基础数据 一、UICR寄存器的说明 UICR(用户信息配置寄存器)**是非易
    的头像 发表于 11-27 17:09 1109次阅读

    嵌入式系统必懂的 20 个寄存器

    嵌入式开发看起来很复杂,但很多操作其实都离不开寄存器寄存器就是MCU内部的存储单元,它们控制着处理和外设的行为。熟悉这些寄存器,你就能更精确地操作硬件,提高开发效率,减少调试时间。
    的头像 发表于 11-14 10:28 649次阅读
    嵌入式系统必懂的 20 个<b class='flag-5'>寄存器</b>

    NVMe高速传输之摆脱XDMA设计32:寄存器功能验证与分析2

    寄存器最大值为 64’hFFFFFFFFFFFFFFFF,到达最大值后一个时钟周期后翻转回 0, 在随机时刻使用 force 将寄存器赋值临近最大值, 当寄存器达到最大值后, 翻转回到 0, 读取数值为 0, 仿真行为符合设计预
    的头像 发表于 10-14 17:06 455次阅读
    NVMe高速传输之摆脱XDMA设计32:<b class='flag-5'>寄存器</b>功能验证与分析2

    ‌SN74LVC595A 8位移位寄存器技术文档总结

    SN74LVC595A器件包含一个8位串行输入、并联输出移位寄存器,该寄存器为8位D型存储寄存器供电。存储寄存器具有并行的 3 态输出。为移位寄存器
    的头像 发表于 09-28 15:09 1105次阅读
    ‌SN74LVC595A 8位移位<b class='flag-5'>寄存器</b>技术文档总结

    ‌SN74HCT595 8位移位寄存器技术解析与应用指南

    Texas Instruments SN74HCT595/SN74HCT595-Q1 8位移位寄存器包含8位串进并出移位寄存器,向8位D类存储寄存器馈送信号。存储寄存器具有并行 3 状
    的头像 发表于 09-19 14:31 596次阅读
    ‌SN74HCT595 8位移位<b class='flag-5'>寄存器</b>技术解析与应用指南

    TPIC6595 8位功率移位寄存器技术文档摘要

    该TPIC6595是一款单片、高压、大电流功率的8位移位寄存器,设计用于需要相对较高负载功率的系统。该器件在输出端包含一个内置电压钳位,用于电感瞬态保护。功率驱动应用包括继电器、螺线管和其他中电流
    的头像 发表于 09-09 11:10 690次阅读
    TPIC6595 8位功率移位<b class='flag-5'>寄存器</b>技术文档摘要

    ‌TPIC6B595 8位功率移位寄存器技术文档总结

    TPIC6B595器件是一款单片、高压、中电流功率8位移位寄存器,设计用于需要相对高负载功率的系统。该器件在输出端包含一个内置电压钳位,用于电感瞬态保护。功率驱动应用包括继电器、螺线管和其他中电流
    的头像 发表于 09-09 10:16 736次阅读
    ‌TPIC6B595 8位功率移位<b class='flag-5'>寄存器</b>技术文档总结

    ‌TLC6C5912 12通道移位寄存器LED驱动技术文档总结

    该TLC6C5912是一款单片、中压、低电流功率 12 位移位寄存器 设计用于需要相对中等负载功率的系统,例如 LED。 该器件包含一个 12 位串行输入并行输出移位寄存器,可为 12 位馈电
    的头像 发表于 08-26 14:16 761次阅读
    ‌TLC6C5912 12通道移位<b class='flag-5'>寄存器</b>LED驱动<b class='flag-5'>器</b>技术文档总结

    使用寄存器点亮LED灯

    学习本章时,配合以上芯片手册中的“19. I/O Ports”章节一起阅读,效果会更佳,特别是涉及到寄存器说明的部分。本章内容涉及到较多寄存器方面的深入内容,对于初学者而言这些内容丰富也较难
    的头像 发表于 05-28 17:37 1040次阅读
    使用<b class='flag-5'>寄存器</b>点亮LED灯

    第四章 什么是寄存器

    本篇文章我们讲解了寄存器的概念、地址映射和寄存器操作等内容,内容比较干,大家有个概念即可,不要求全部熟记掌握,有需要时可重复查阅观看。下一篇我们将开始进行实操内容,通过控制单片机的GPIO来点亮一颗LED,敬请期待!
    的头像 发表于 05-21 14:23 1135次阅读
    第四章 什么是<b class='flag-5'>寄存器</b>

    74HC594-Q100;74HCT594-Q100带输出寄存器的8位移位寄存器规格书

    电子发烧友网站提供《74HC594-Q100;74HCT594-Q100带输出寄存器的8位移位寄存器规格书.pdf》资料免费下载
    发表于 02-09 15:19 0次下载
    74HC594-Q100;74HCT594-Q100带输出<b class='flag-5'>寄存器</b>的8位移位<b class='flag-5'>寄存器</b>规格书

    24l01寄存器列表指南免费下载

      寄存器的功能是存储二进制代码,它是由具有存储功能的触发组合起来构成的。一个触发可以存储1位二进制代码,故存放n位二进制代码的寄存器,需用n个触发
    发表于 01-22 17:25 1次下载

    STC15系列常用寄存器汇总免费下载

      寄存器的功能是存储二进制代码,它是由具有存储功能的触发组合起来构成的。一个触发可以存储1位二进制代码,故存放n位二进制代码的寄存器,需用n个触发
    发表于 01-22 17:24 10次下载

    XILINX FPGA CLB单元之移位寄存器

    一、移位寄存器 SLICEM函数发生也可以配置为32位移位寄存器,而无需使用slice中可用的触发。以这种方式使用,每个LUT可以将串行数据延迟1到32个时钟周期。 移入D(DI1
    的头像 发表于 01-16 17:45 1454次阅读
    XILINX FPGA CLB单元之移位<b class='flag-5'>寄存器</b>

    TPS80032寄存器手册

    电子发烧友网站提供《TPS80032寄存器手册.pdf》资料免费下载
    发表于 12-21 09:08 0次下载
    TPS80032<b class='flag-5'>寄存器</b>手册