QCC51xx学习笔记:KSE简介和跑通官方仿真例程

本文介绍了QCC51xx系列芯片的KSE(Kymera Simulation Environment)仿真环境,包括KSE系统框架、Kalsim和Kymera的职责。通过跑通官方提供的loopback_download_test例程,展示了获取仿真结果和加速仿真的方法,并解释了在验证仿真结果时发现的误差原因,最后总结了KSE在算法移植工作中的优势和待探索的领域。
摘要由CSDN通过智能技术生成

为了方便大家学习,现与思度科技联合推出QCC300x/CSR867x/QCC30xx/QCC51xx学习板【思度科技蓝牙开发板】

技术交流QQ群号:743434463
开发板会员QQ群号:725398389(凭订单号入群,赠PPT、项目源码、视频教程)
——————————正文分割线———————————–

1. 引言

高通以CSR867X系列为基础,开发了下一代高性能蓝牙SOC系列QCC30XX/QCC51XX。新系列整体的硬软件能力都有了显著的提升,包括全新的音频仿真环境KSE。

从开始阅读KSE描述文档,到第一次跑通例程,再到分析定位仿真误差,经历了漫长的三个月。为了让大家少走一些弯路,将过程中遇到的问题和解决方案分享出来(文中例程和文档都可以在思度开发板QCC512X资料库中下载)。

2. KSE简介

官方介绍文档如下文档:

  • 80-cg060-1_ab_kymera_introduction.pdf
  • 80-cg335-1_aa_kymera_simulation_environment_(kse)_training.pdf
  • 80-cg887-1_ab_kymera_simulation_environment_(kse)_user_guide.pdf

详细内容建议读者阅读原版手册,在此只抓几个重点概念简单讲一下。

首先我们需要了解KSE的系统框架,示意图如下:

在这里插入图片描述

  • KSE: kymera simulation environment,即kymera仿真环境。包含Kalsim和kymera两部分。
  • Filesystem:仿真数据输入和输出以文件形式存在,KSE从文件中读取数据,经过处理后再写入文件。文件可以是raw/wav/sbc等各种格式,方便与算法开发工具(如matlab)对接,构建从算法原型开发到嵌入式平台仿真的全链路环境。
  • Kalsim:高通kalimba DSP的PC平台软核版本,即芯片模拟器,可以真实模拟kalimba dsp的处理结果,并提供调试接口。
  • Kymera:运行在kalimba dsp内的专用于音频处理的操作系统,C语音和汇编语言混合编程。负责进程管理、内存分配、消息队列、音频接口管理等,需要开发者重点关注。
    在这里插入图片描述
  • Python Shell:一套Python语言编写的脚本,可以方便地运行、调试、测试KSE环境,包含uut, kymera, endpoint, capability, stream, graph, kalcmd, acat等工具。Python工具集可以实现仿真过程的高度自动化,同时兼容各种第三方插件,值得投入时间精力重点学习。

对于算法移植工程师来说,KSE中的kymera API、Python工具集API和文件接口是需要重点关注的,kalsim对我们来说是个黑盒,不用过多关注。软件开发需要掌握C语言、汇编语言,熟悉matlab脚本、python脚本和json格式。

3. 跑通官方仿真例程

3.1. 获取仿真结果

高通官方提供了loopback_download_test例程作为最简的算法移植验证环境,其音频链路框图如下:
在这里插入图片描述
官方文档给出了各个部分的详细描述,可以参考如下文档:

  • 80-ct522-1_ae_kymera_api_reference.pdf
  • 80-cf424-1_ac_kymera_utility_api_reference.pdf
  • 80
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值