[STM8] 中场休息,问个问题:STM8有没有指令编码文档?

[复制链接]
4608|7
 楼主| Simon21ic 发表于 2010-6-30 03:20 | 显示全部楼层 |阅读模式
本帖最后由 Simon21ic 于 2010-6-30 03:29 编辑

准备优化一下自己的STM8_SWIM下载线,需要写一个flashloader。
看了一下STVP里使用的flashloader算法,还是觉得有一些可以做到更加优化/简化的方法。

STM8的指令集找到了,但是里面没有详细的指令编码,虽然编码可以使用STM8的汇编器生成,但是最好能够一个文档用于在调试过程中核对。
STM32的Thumb2指令集有公开的编码格式,当然,这个是ARM公司公开的。
能否给个STM8的指令编码文档的链接?

另外,STVD能否生成在RAM里运行的代码,并使用st-link下载到RAM中调试?


最后,在芯片的Datasheet里,看到DM(Debug module)的相关寄存器,但是,在STM8 Reference Manual里,没有找到这些寄存器的详细定义和使用方法,这个是否是公开的?能否提供链接?
----已经找到,在这里:http://www.st.com/stonline/books/pdf/docs/14024.pdf。什么时候本大爷高兴,在OpenOCD里加上STM8的支持,哇哈哈哈哈哈哈。
dami 发表于 2010-6-30 09:18 | 显示全部楼层
这个还真没注意哦.
无冕之王 发表于 2010-6-30 10:26 | 显示全部楼层
好像没有
无冕之王 发表于 2010-6-30 10:26 | 显示全部楼层
我也不太确定
香水城 发表于 2010-6-30 11:51 | 显示全部楼层
这个文档中,在每个指令的详细说明中有指令编码:PM0044  STM8 CPU programming manual

例如ADC指令的说明如下:
STM8_Opcode.GIF
 楼主| Simon21ic 发表于 2010-6-30 12:19 | 显示全部楼层
原来在这里,和一般习惯的写法不一样啊。
这个写法,还要研究一下。。。。。。
 楼主| Simon21ic 发表于 2010-6-30 21:25 | 显示全部楼层
本帖最后由 Simon21ic 于 2010-6-30 21:29 编辑

h:\myproject\versaloon\data\stm8\flashloader\main.asm(5): lyn : Error 5: No information on start address of class 'ram'

看来,STVP不支持写RAM里的程序吗?
另外,STVP不支持模拟调试吗?
 楼主| Simon21ic 发表于 2010-7-1 00:39 | 显示全部楼层
试了一下IAR,这个是可以模拟调试的。
做了一个最简单的测试用的flashloader:
static uint8_t stm8_flashloader[] =
{
        0xA6, 0x5A,                                // LD        A, #$5A
        0x20, 0xFE,                                // JRA        $
        0x9D,                                        // NOP
};

运行正常,stall后读取的寄存器:
Info:   A = 0x5A(90)
Info:   PC = 0x000002
Info:   X = 0x0000
Info:   Y = 0x0000
Info:   SP = 0x17FF
Info:   CCR = 0x00000028

看来基本米问题了。
PS:STM8的汇编指令的opcode,比thumb2简单好多。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

266

主题

2597

帖子

104

粉丝
快速回复 在线客服 返回列表 返回顶部