4236|7

86

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

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



准备优化一下自己的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的支持,哇哈哈哈哈哈哈。
此帖出自stm32/stm8论坛

最新回复

net
                                 试了一下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简单好多。  详情 回复 发表于 2010-7-1 00:39
点赞 关注
 

回复
举报

80

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
                                 这个还真没注意哦.
此帖出自stm32/stm8论坛
 
 

回复

70

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
                                 好像没有
此帖出自stm32/stm8论坛
 
 

回复

80

帖子

0

TA的资源

一粒金砂(初级)

4
 
                                 我也不太确定
此帖出自stm32/stm8论坛
 
 
 

回复

78

帖子

0

TA的资源

一粒金砂(初级)

5
 
这个文档中,在每个指令的详细说明中有指令编码:PM0044  STM8 CPU programming manual

例如ADC指令的说明如下:

STM8_Opcode.GIF (35.15 KB)

STM8_Opcode.GIF

此帖出自stm32/stm8论坛
 
 
 

回复

82

帖子

0

TA的资源

一粒金砂(初级)

6
 
原来在这里,和一般习惯的写法不一样啊。
这个写法,还要研究一下。。。。。。
此帖出自stm32/stm8论坛
 
 
 

回复

83

帖子

0

TA的资源

一粒金砂(初级)

7
 


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

看来,STVP不支持写RAM里的程序吗?
另外,STVP不支持模拟调试吗?
此帖出自stm32/stm8论坛
 
 
 

回复

76

帖子

0

TA的资源

一粒金砂(初级)

8
 
试了一下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简单好多。
此帖出自stm32/stm8论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/7 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表