gpt4 book ai didi

assembly - 有没有人在 xcore 的基于汇编器的 LED 闪光灯上取得成功?

转载 作者:行者123 更新时间:2023-12-04 06:51:34 32 4
gpt4 key购买 nike

我喜欢 http://www.xmos.com芯片,但想要对正在发生的事情有一个较低层次的了解。基本上是汇编。我正在尝试整理一些像 LED 闪光灯这样简单的东西,设置 LED,计数到 N 清除 LED,计数到 N,永远循环。

当然我可以反汇编一个 10 行的 XC 程序,但是如果您尝试过,您会发现每个程序中都有很多膨胀,哪些位用于支持编译器输出以及哪些位实际设置了 gpio ?

编辑:

XC码

#包括
输出端口流血 = PORT_BUTTONLED ;
int主(){
流血<:0b0011;
而 (1)
;
返回0;
}

构建命令

源集环境
xcc bob.xc -target=XC-1A -o bob.xe
xsim --max-cycles 2000 --vcd-tracing "-o bob.vcd -ports -cycles -threads -timers -instructions -functions"bob.xe

编辑 5

这是答案

.globl _start
_开始:
ldc r0,4
ldc r2,8
ldc r3,16
ldc r1, 100
不是主要的:
子 r1,r1,1
bt r1, notmain

ldap r11,常量
设置 dp,r11

ldc r3, 0x6
setc res[r3], 0x8
setc res[r3], 0xf

ldw r3,dp[0x0]
setc res[r3],0x8
ldc r1,0x6
setclk res[r3],r1

最佳:

ldc r0, 0x8
输出 res[r3], r0
延迟

ldc r0, 0x4
输出 res[r3], r0
延迟

ldc r0, 0x2
输出 res[r3], r0
延迟

ldc r0, 0x1
输出 res[r3], r0
延迟

ldc r0, 0x2
输出 res[r3], r0
延迟

ldc r0, 0x4
输出 res[r3], r0
延迟



常数:
.word 0x00040200

延迟:
ldc r2, 1000
达:
ldc r1, 10000
D b:
子 r1,r1,1
bt r1, db
子 r2,r2,1
bt r2, da
回复 0x0

构建和加载上述汇编程序 m.s:

xcc m.s -target=XC-1A -nostartfiles -o m.xe
xrun m.xe

如果您摆脱延迟,您可以模拟并查看芯片的焊盘/引脚,以便您可以在合理长度的模拟中看到发生的事情

xsim --max-cycles 2000 --vcd-tracing "-o m.vcd -ports -cycles -threads -timers -instructions -functions -pads"m.xe

但是 gtkwave 不喜欢语法,所以要使用 gtkwave 查看 m.vcd 文件,我必须编辑 .vcd 文件和

从:
$var 线 1 paa10 0:X0D61 $end
到:
$var 线 1 paa10 X0D61 $end

基本上删除 0: 对于所有 paa 变量定义行。

使用上面的汇编器 x0d14、x0d15、x0d19、x0d20 是 wiggle 可以从他们的文档中看到连接的焊盘。

这个神奇的数字来自一个包含文件:

#define XS1_PORT_4C 0x40200

编辑 6

亨克,感谢您的帮助。我正在回顾我已经走了多远并且不理解 0x6 和 setclk 的东西,并且将不得不重新提问或深入挖掘。下面的代码确实开始摆动端口,但随后 xcore 似乎进行了线程交换并基本上挂起,因此它仍然不是我希望的简单程序。而且我明白这不是一个简单的核心(这就是为什么我想在这个层次上理解它以充分利用它)。

.globl _start
_开始:
ldc r1, 100
不是主要的:
子 r1,r1,1
bt r1, notmain

ldc r3,0x4020
shl r3,r3,4
setc res[r3],0x8
最佳:
ldc r0, 0x8
输出 res[r3], r0
ldc r0, 0x4
输出 res[r3], r0
ldc r0, 0x2
输出 res[r3], r0
ldc r0, 0x1
输出 res[r3], r0
ldc r0, 0x2
输出 res[r3], r0
ldc r0, 0x4
输出 res[r3], r0

最佳答案

发布程序集,我会为您查看它。听起来不错。

编辑:

   0x000100ac: 00 f0 45 58: ldw (lru6)      r1, dp[0x5]
0x000100b0: d2 a6: mkmsk (rus) r0, 0x2
0x000100b2: c1 ae: out (r2r) res[r1], r0

我认为这是您要寻找的部分。我需要找到一份 XMOS 引用手册,但根据 main 中的控制流,这必须是访问 bleed channel 的部分。要确认它,您可以在 XC 代码中添加一个标志并在 while 循环中翻转 LED。这应该在程序集输出中添加对上述内容的类似访问。

根据指令集引用(第 123 页),out 的第一个操作数是端口,第二个是数据。 dp[0x5]操作数看起来像是从某种全局银行中获取端口句柄,然后用于查找相关资源。

一位知情人士向我建议您尝试使用 -O2 来清理代码。如果你想了解正在发生的事情,我会跳过所有的初始化代码,它在大多数平台上总是一团糟。如果您只关注主标签和下一个过程 ( DoException ) 之间的行,那么您应该会看到映射到您编写的部分的可管理数量的代码。较小的 btxx标签是控制结构(while 循环、if 语句)的跳转目标。

关于assembly - 有没有人在 xcore 的基于汇编器的 LED 闪光灯上取得成功?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3050637/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com