| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2884 人关注过本帖
标题:关于堆栈破坏的问题
只看楼主 加入收藏
li478601862
Rank: 1
等 级:新手上路
帖 子:8
专家分:2
注 册:2012-10-26
结帖率:100%
收藏
已结贴  问题点数:5 回复次数:9 
关于堆栈破坏的问题
    在xp32位系统下编写的一个应用程序运行完全正常,现在想在64位系统下运行,提示堆栈破坏始终无法运行,查了下可能是因为动态链接库调用导致的堆栈问题,试了很久一直不知怎么解决,望知道的朋友不吝赐教,谢谢!
搜索更多相关主题的帖子: 系统 应用程序 动态 
2012-12-13 16:12
炎黄宇宙
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:53
专家分:104
注 册:2012-11-12
收藏
得分:1 
是不是出现递归调用了
2012-12-13 16:16
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:1 
遇到过 堆损坏的提示,后来发现是指针非法。


[fly]存在即是合理[/fly]
2012-12-13 16:24
crystall
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:7
帖 子:184
专家分:809
注 册:2012-12-1
收藏
得分:1 
可否贴个代码观摩观摩
2012-12-13 16:35
li478601862
Rank: 1
等 级:新手上路
帖 子:8
专家分:2
注 册:2012-10-26
收藏
得分:0 
回复 2楼 炎黄宇宙
没有涉及到递归调用
2012-12-14 09:15
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:1 
估计个别api对32位或者64位 区别很大吧

DO IT YOURSELF !
2012-12-14 09:25
li478601862
Rank: 1
等 级:新手上路
帖 子:8
专家分:2
注 册:2012-10-26
收藏
得分:0 
回复 4楼 crystall
BOOL pcie::ReadBAR0(DWORD offset,UINT32*outdata,UINT numbyte=0)
{
    DWORD dw;
    if(dw=WDC_ReadAddr32(hDev,0,offset,outdata),dw!=0)
    {
        strcpy(infor"读取失败!\n");
        strcat(infor,Stat2Str(dw));
        return FALSE;
    }

    return TRUE;
}

调用这个子函数里面涉及到WDC_ReadAddr32这个函数,这个函数是动态链接库"windrvr.h"里封装的函数
声明如下:
DWORD DLLCALLCONV WDC_ReadAddr32(WDC_DEVICE_HANDLE hDev, DWORD dwAddrSpace,
    KPTR dwOffset, UINT32 *val);
在32位系统下调用完全OK,换成64位系统提示堆栈被破坏,我刚开始以为改成WDC_ReadAddr64就可以了,后来发现跟这个没关系
2012-12-14 09:47
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
UINT32 *val  这不是声明32位指针吗  估计64位够呛

DO IT YOURSELF !
2012-12-14 09:52
li478601862
Rank: 1
等 级:新手上路
帖 子:8
专家分:2
注 册:2012-10-26
收藏
得分:0 
回复 3楼 azzbcc
好像没有非法指针,涉及到的代码主要如下:
BOOL pcie::ReadBAR0(DWORD offset,UINT32*outdata,UINT numbyte=0)
{
    DWORD dw;
    if(dw=WDC_ReadAddr32(hDev,0,offset,outdata),dw!=0)
    {
        strcpy(infor,"读取错误!\n");
        strcat(infor,Stat2Str(dw));
        return FALSE;
    }

    return TRUE;
}
WDC_ReadAddr32调用有问题,提示堆栈破坏
图片附件: 游客没有浏览图片的权限,请 登录注册
2012-12-14 09:55
li478601862
Rank: 1
等 级:新手上路
帖 子:8
专家分:2
注 册:2012-10-26
收藏
得分:0 
以下是引用wp231957在2012-12-14 09:52:55的发言:

UINT32 *val  这不是声明32位指针吗  估计64位够呛
应该没问题,因为前面也用这种方法调用了其他函数:
BOOL pcie::ReadCfg(DWORD offset,UINT32*outdata,KPTR numbyte)
{
    if (!hDev)
    {
        strcpy(infor,"无效设备句柄!");
        return FALSE;
    }
    memset(outdata,0,4);
    DWORD dw;
    if(dw=WDC_PciReadCfg(hDev,offset, outdata, numbyte),dw==0)
        return TRUE;
    strcpy(infor,Stat2Str(dw));
    return FALSE;
}
这里面调用WDC_PciReadCfg(hDev,offset, outdata, numbyte)没有出现堆栈破坏
2012-12-14 10:09
快速回复:关于堆栈破坏的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019696 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved