打印
[STM8]

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

[复制链接]
3561|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
本帖最后由 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 | 只看该作者
我也不太确定

使用特权

评论回复
5
香水城| | 2010-6-30 11:51 | 只看该作者
这个文档中,在每个指令的详细说明中有指令编码:PM0044  STM8 CPU programming manual

例如ADC指令的说明如下:

STM8_Opcode.GIF (35.15 KB )

STM8_Opcode.GIF

使用特权

评论回复
6
Simon21ic|  楼主 | 2010-6-30 12:19 | 只看该作者
原来在这里,和一般习惯的写法不一样啊。
这个写法,还要研究一下。。。。。。

使用特权

评论回复
7
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不支持模拟调试吗?

使用特权

评论回复
8
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

粉丝