免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3437 | 回复: 2
打印 上一主题 下一主题

大端处理器接小端外设? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-11-16 12:33 |只看该作者 |倒序浏览
RT  大端处理器 是咋连小端外设? 在linux中,iowrite16 ioread16这些默认输出都是小端模式?

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
2 [报告]
发表于 2010-11-16 13:22 |只看该作者
自己做一下转换吧

论坛徽章:
0
3 [报告]
发表于 2010-11-16 15:06 |只看该作者
本帖最后由 xs3c 于 2010-11-16 15:07 编辑

谢谢版主的回答,可能我描述的不是太清楚。
通过查看powerpc部分的代码中发现iowrite16调用writew  而writew在asm-generic/io.h中定义为
#define writew(b,addr) __raw_writew(__cpu_to_le16(b),addr  
所以认为linux 只是powerpc下都是输出都是默认小端。也就是输出到数据线上的数据已经同__cpu_to_le16转换了。
那么我的第一个问题就是 :硬件连接的时候,是否就应该按照处理器是小端的方式将处理器的数据线与外设的数据线连接?
第二个问题: 那么处理器是小端的话那么数据线与外设的数据线连接。是否
cpu bit0 ---------bit15
外设 bit0 ---------bit15
而大端处理器要是linux中没有做__cpu_to_le16的转换工作,数据线的连接是否是应该:
cpu    bit0-------bit15
外设   bit15------bit0。

以上是我的理解,请教各位大侠是否正确?
这所以有上面的问题,是我在调试一个网卡驱动的时候,板子是powerpc配置大端,网卡芯片寄存器是小端, 驱动程序里面原来直接用ioread16 iowrite16。结果发现设置的寄存器值刚好是大小端反的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP