OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7400|回复: 9

sprintf函数导致程序进入HardFault_Handler如何解决?

[复制链接]

18

主题

61

帖子

0

精华

初级会员

Rank: 2

积分
178
金钱
178
注册时间
2013-4-24
在线时间
6 小时
发表于 2014-12-15 13:32:50 | 显示全部楼层 |阅读模式
5金钱
我用的MINI STM32开发板,一开始运行正常,运行了一段时间以后,程序出错,进入HardFault_Handler了。是什么原因导致的呢??是我的sprintf用法有问题么?求指教。

我程序定义的变量是这样的:
u8 JSESSIONId[32];
float longitude_g=0;
float latitude_g=0;
u8  *pt;
pt = mymalloc(150);
sprintf((char*)pt,"218.244.129.124/ymtrack/position.action?longitude=%f&latitude=%f&JSESSIONId=%s",longitude_g,latitude_g,JSESSIONId);      

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2014-12-15 14:52:09 | 显示全部楼层
float longitude_g=0;
float latitude_g=0;
这个两个变量做一次4字节对齐试试,也就是下面这样:
__align(4) float longitude_g=0;
__align(4) float latitude_g=0;
开往春天的手扶拖拉机
回复

使用道具 举报

18

主题

61

帖子

0

精华

初级会员

Rank: 2

积分
178
金钱
178
注册时间
2013-4-24
在线时间
6 小时
 楼主| 发表于 2014-12-15 17:11:05 | 显示全部楼层
回复【2楼】zuozhongkai:
---------------------------------
这样也不可以哦,
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2014-12-15 17:53:21 | 显示全部楼层
那就不清楚了
开往春天的手扶拖拉机
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2014-12-15 18:23:33 | 显示全部楼层
尝试一次8字节对齐__align(8)
开往春天的手扶拖拉机
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2014-12-15 18:44:52 | 显示全部楼层
就这么点代码,看不出问题。仿真跟踪下了。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

18

主题

61

帖子

0

精华

初级会员

Rank: 2

积分
178
金钱
178
注册时间
2013-4-24
在线时间
6 小时
 楼主| 发表于 2014-12-16 11:26:02 | 显示全部楼层
回复【6楼】正点原子:
---------------------------------
如果我把PT作为全局变量定义成数组的话 就不会有问题  说明你的动态内存函数有问题啊

    u8 pt[150];
    void funcxxx(void)
    {
            u8 JSESSIONId[32];
            float longitude_g=0;
            float latitude_g=0;
            //u8  *pt;
            //pt = mymalloc(150);
            sprintf((char*)pt,"218.244.129.124/ymtrack/position.action?longitude=%f&latitude=%f&JSESSIONId=%s",longitude_g,latitude_g,JSESSIONId);        
    }
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2014-12-16 23:20:49 | 显示全部楼层
回复【7楼】andy93762:
---------------------------------
内存管理没问题的,我已经验证过N次了。
看看是不是需要8字节对齐导致的,将内存管理限制为8字节对齐再试试。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

18

主题

61

帖子

0

精华

初级会员

Rank: 2

积分
178
金钱
178
注册时间
2013-4-24
在线时间
6 小时
 楼主| 发表于 2015-3-17 09:17:06 | 显示全部楼层
回复【8楼】正点原子:
---------------------------------
我把mini开发板的芯片STM32F103RC换成STM32F103C8, RAM从48K变成了20K,内存管理要如何修改呢?改动哪里就可以了呢
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-3-18 00:12:42 | 显示全部楼层
回复【9楼】andy93762:
---------------------------------
请看教程
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-24 20:40

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表