8051内核单片机xdata的处理

    在项目开发中遇到需要使用8051核的单片机去驱动oled屏显示数据量较大的一些图片,项目中使用的是新唐N76E003AT20的8051单片机,将底层OLED的驱动和显示函数从已经量产的项目中移植过来发现屏幕无法点亮。

    针对这种问题,首先就去查找写给屏幕的驱动命令有没有传正确,于是先找到写一个数据的函数,仔细调试发现,发现该函数无法得到上层调用函数传递过来的参数,所以,每一次传入的都默认是形参0。

    根据这个现象找到问题出现的原因是堆栈已经溢出,之后我将其他所有的函数去不屏蔽掉,只留下操作屏显示的函数和一些底层的函数,这样在调试屏的时候就不会受到其他因素的影响,去掉之后发现xdata有之前的3000变成了200多,data没有变化,code相应的也减少了。

    然后再进行调试,这个时候发现屏幕可以正常的驱动显示我需要的内容。

    当然,上面说的这些都只是简单的概述一些我在项目中的处理的结果。

    现在查找原因,导致xdata占用这么多的内存资源的原因是因为我取模的很多我需要显示的图片和字母,数字全部都是以全局变量的形式保存的,这些对内存消耗很大。

    在函数得调用过程中出现了比较深的函数调用,简单的说就是函数里面又调用了其他函数,调用的层数比较多,这样就很容易导致堆栈的溢出。

    之后我将所有的函数继续添加到工程中进行编译运行,不出所料,屏还是没有驱动成功。

    我认为主要的原因是全局变量(尤其是取模的数据)占用了大量的xdata空间,导致的溢出,从而使函数无法得到调用。

    解决办法:(1)减少函数的调用层次,两层最多

                        (2)将这些全局变量使用code进行定义。例如 u8 code pixelLowBmp;

    在使用了这种方法之后,明显的由3000多的xdata变为200多,而code其实并没有多大的变化,这是为什么呢?等我有时间的时候再去仔细的区分这里面的一些差异。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,521评论 25 708
  • error code(错误代码)=0是操作成功完成。error code(错误代码)=1是功能错误。error c...
    Heikki_阅读 3,457评论 1 9
  • 近日个人的状态日益低迷糟糕。主要原因来至于对于未来和职业的迷茫,对于经济压力的焦虑。深层次的原因还是对自己的职业能...
    lafs阅读 451评论 0 0
  • 昨天妈妈在微信上给我发来视频,我接起后并不怎么开心,但不是因为她我才不开心,而是因为我在大学的碌碌无为。...
    暮云朝露里阅读 521评论 4 5
  • 有人喜欢像英语那样把日语语法成分分成我们熟知的主谓宾定状补成分,也有人从日语特点出发将所有除了谓语之外的成...
    言语砌生平阅读 214评论 1 1