69书吧最新网址:www.69hao.com
首页 > 精品推荐 > 重生:从点亮科技树开始 > 第55章 落地

第55章 落地(1/2)

目录
好书推荐: 人在北宋,江湖演道法 完蛋了!太子爷全家都是她前男友 我都准帝巅峰了,怎么还要收徒 开局禁区兽皇,捡了个女帝当女儿 问鼎.青云 满宫不孕,唯我三年抱俩! 扮演小白花,在五零享福吃瓜 我,网球之神,与南次郎开创时代 叮!大佬从每天跑步十公里开始 与公主互穿后,朕杀穿皇城登女帝

五月中旬,蓝湾通信发来了第一批工程开发用的嵌入式硬体平台。

两箱银灰色的铝合金机箱,每箱四台,一共八台。每台机箱里装著一块定製的信號处理板卡——双核dsp加fpga的异构架构,这是天穹地面终端的核心计算平台。

张磊拆开第一台机箱的时候,手指都在微微发抖。

“城哥,这板子的做工也太精致了吧。“他捧著板卡翻来覆去地看,“比我们实验室用的开发板高了好几个档次。“

“这是蓝湾通信和晶片厂联合定製的。“左城接过板卡看了一眼丝印,“dsp主频六百兆赫,fpga是二十八纳米工艺,片上ram两兆字节。和我们仿真用的参数模型一致。“

“一致“这个词他说得很有信心。但三天后他就知道自己错了。

问题出在第一次上板测试。

方泽把多星管道调度器的代码移植到dsp上,编译通过,烧录成功,启动运行——然后系统在第十七秒崩溃了。

“內存溢出。“方泽盯著调试器的输出,眉头拧成了一团,“堆栈空间不够。“

左城走到他旁边看了一眼数据。仿真环境里调度器的峰值內存占用是一点六兆字节,而dsp的片上ram是两兆字节,理论上应该够用。但实际运行时,编译器生成的代码比仿真环境的模擬代码体积大了百分之四十——因为真实的dsp指令集和仿真用的通用指令集不一样,某些运算需要更多的中间变量和临时缓衝区。

一点六兆乘以一点四,等於二点二四兆。超了。

“仿真和实物之间永远有gap。“左城的语气没有意外,只有冷静,“这是工程开发阶段必须面对的问题。仿真验证了算法的正確性,但代码的工程实现必须针对真实硬体重新优化。“

“怎么优化?两兆的ram是硬限制,改不了。“方泽问。

“改代码,不改硬体。“左城坐到方泽旁边,打开了调度器的原始码,“第一步,做內存剖析——找出哪些数据结构占了最多的空间。第二步,做数据压缩——能用短整型的不要用长整型,能復用缓衝区的不要另开新空间。第三步,做代码瘦身——把编译器生成的冗余指令手动优化掉。“

这三步说起来简单,做起来是一刀一刀削肉的苦活。

左城和方泽花了整整一周,把调度器的代码从头到尾重写了一遍。不是改算法——算法不用动——而是改每一行代码的实现方式,让它在有限的內存空间里儘可能高效地运行。

七天后重新上板。峰值內存占用——一点七八兆。稳了。系统运行了十二个小时,没有崩溃,没有溢出,调度器的响应时间和仿真结果完全吻合。

方泽靠在椅背上长出了一口气。他的眼镜片上有两个明显的指印——这一周他推眼镜的频率比平时高了三倍。

“这种活儿比写算法累多了。“他难得抱怨了一句。

“算法是创造,工程优化是雕刻。“左城说,“两种累法。“

但这只是第一个模块。

接下来的三周里,同样的问题在其他三个模块上依次出现。自適应参数共享引擎的內存问题更严重——环形缓衝区在dsp上的对齐要求和仿真环境不同,导致实际占用比预期多了百分之三十。波束协同控制器的问题不在內存,在时序——fpga的时钟频率和仿真的理想时钟有微小的偏差,导致分层精度切换的判断逻辑偶尔会错过一个时钟周期,造成波束指向的瞬间抖动。

频谱感知前端反而是最顺利的——因为这个模块的嵌入式优化在架构设计阶段就已经做到位了,定点化、dma流水线、候选循环频率预筛选,每一步都是针对真实硬体设计的,上板后只做了几处寄存器配置的小修改就跑通了。

“之前砍的那三刀没白砍。“刘伟感慨了一句。

本章未完,点击下一页继续阅读。

目录
新书推荐: 让你代课,你教学生核聚变? 顶级妇医:开局查出名媛怀外教种 裂日:从全图视野开始 诸天逆袭,从绣春刀开始! 随父入赘后,假娇软成家属院团宠 人在港综,开局融合白银大超 直播探诡,什么叫只有我看不见诡 同时穿越,都是最终BOSS! 枕上桃色 雪中:融合阿良,木剑碎天门!
返回顶部