BLSP接口_jcom接口

BLSP接口_jcom接口http://huaqianlee.github.io/2016/04/27/Uav/Qualcomm-uav-blsp-port/概述BLSP是高通对于低速接口的一种管理方式,8074平台含有两个BLSP(BAMLow-SpeedPeripheral)块,对应于12个BLSP端口。每一个BLSP块含有最多六个QualcommUniversalPe

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

http://huaqianlee.github.io/2016/04/27/Uav/Qualcomm-uav-blsp-port/

概述

BLSP是高通对于低速接口的一种管理方式,8074 平台含有两个BLSP(BAM Low-Speed Peripheral) 块,对应于12个BLSP端口。 每一个BLSP块含有最多六个Qualcomm Universal Peripheral (QUP)或六个Uart cores,通过相关手册查询到每个外设属于BLSP多少。结构框图如下:
BLSP

  1. BAM(Bus Access Manager)is used to move data to/from the peripheral buffers; 2.每个BLSP外设静态连接到一对BAM管道,BLSP支持BAM 和non-BAM-based 数据传输。


每一个QUP可以被配置为I2C, SPI, UART, UIM接口等,如下:
blsp_pin

自定义BLSP口,配置TZ

这些端口在aDSP和应用处理器之间共享。为了让BLSP端口独立使用,我们可以在TrustZone(TZ)中定义BLSP 端口的分配,没有权限的子系统访问BLSP 端口将导致系统崩溃。 高通默认已经做好了配置。在DspAL中, 提供了一组设备文件路径映射到硬件,无人机用到的相关口已经在TZ中配置好了,如下:

1
2
3
4
SPI:  /dev/spi-[1~12]  对应于   BLSP[1~12]上的SPI设备
I2C: /dev/iic-[1-12]      对应于   BLSP[1~12]上的I2C设备
UART: /dev/tty-[1-4]
# UAV 8074 最多支持4个串口设备,每一个串口设备对应一个BAM设备,

如果要自定义新的端口,需按于如下方式配置:

计算APPS BLSP值

apps-BLSP
根据倒数第二列(对应于BAM pipe)计算出结果如下:
APPS BLSP1 : 0x00C3000C [ Format : 0x00 (Apps BLSP1 QUP) ( Apps BLSP1 UART) ]
APPS BLSP2 : 0x00F30F33 [ Format : 0x00 (Apps BLSP2 QUP) ( Apps BLSP2 UART) ]

Apps列对应Y,则表明BLSPx配为Uart或QUP,下同。

计算ADSP BLSP值

adsp-BLSP
ADSP BLSP1 = 0x0003FF00 [ Format : 0x00 (Adsp BLSP1 QUP) ( Adsp BLSP1 UART) ]
ADSP BLSP2 = 0x00FC00CC [ Format : 0x00 (Adsp BLSP2 QUP) ( Adsp BLSP2 UART) ]

通过计算的值在TZ中配置

路径:trustzone_images\core\hwengines\bam\8974\bamtgtcfgdata_tz.h

BLSP1:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Replace the highlighted values with ADSP BLSP1 and APPS BLSP1
 
bam_sec_config_type bam_tgt_blsp1_secconfig =
{
      
      
    {
      
      
#ifdef FEATURE_DRONE_CUSTOMIZATION_1 
#ifdef BAM_TZ_DISABLE_SPI
        {
      
      0x00C3000C   , TZBSP_VMID_AP, 0x0, TZBSP_VMID_AP_BIT},       // APPS BLSP1
        {
      
      0x0003FF00   , TZBSP_VMID_LPASS, 0x0, TZBSP_VMID_LPASS_BIT}, // ADSP BLSP1
        {
      
      0x00000000, TZBSP_VMID_MSS, 0x0, TZBSP_VMID_MSS_BIT},
#else
        {
      
      0x00C3000C   , TZBSP_VMID_AP, 0x0, TZBSP_VMID_AP_BIT},       // APPS BLSP1
        {
      
      0x0003FF00   , TZBSP_VMID_LPASS, 0x0, TZBSP_VMID_LPASS_BIT}, // ADSP BLSP1
        {
      
      0x00000000, TZBSP_VMID_MSS, 0x0, TZBSP_VMID_MSS_BIT},
        {
      
      0x00300000, TZBSP_VMID_TZ, 0x0, TZBSP_VMID_TZ_BIT}
      
#endif /*BAM_TZ_DISABLE_SPI*/
...
}

BLSP2:

1
2
3
4
5
6
7
8
9
10
11
12
bam_sec_config_type bam_tgt_blsp2_secconfig =
{
      
      
    {
      
      
#ifdef FEATURE_DRONE_CUSTOMIZATION_1 
        {
      
      0x00F30F33   , TZBSP_VMID_AP, 0x0, TZBSP_VMID_AP_BIT},       // APPS BLSP2
        {
      
      0x00FC00CC  , TZBSP_VMID_LPASS, 0x0, TZBSP_VMID_LPASS_BIT}   // ADSP BLSP2
#else
        {
      
      0x003C0FFF, TZBSP_VMID_AP, 0x0, TZBSP_VMID_AP_BIT},
        {
      
      0x00C3F000, TZBSP_VMID_LPASS, 0x0, TZBSP_VMID_LPASS_BIT}
#endif
...
}

怎么工作

在启动期间,aDSP将加载BLSP配置文件初始化串口设备。为了是能运行时配置,可在/usr/share/data/adsp/blsp.config中定义串口设备和BAM端口的映射,bam对应于BLSP。如:

1
2
3
4
tty-1 bam-9
tty-2 bam-6
tty-3 bam-8
tty-4 bam-2

如果串口设备只用TX和RX,需要在最后一行加入 “[2-wire]”作为标示,否则默认为四线:TX,RX,CTS和RTS。

  1. 串口根据需要配置,不一定所有都配置;2. 如果运行时指定路径文件不存在或者加载失败,如上所示的默认配置将被使用;3. /usr/share/data/adsp/blsp.config最好设置为只读模式。

Reference

80-NA157-24 Low-Speed Peripherals Overview.pdf
80-NB849-1 Rev. J APQ8074A PQ8074AB Device Specification.pdf
80-H9580-1-J_QUALCOMM SNAPDRAGON FLIGHT DEVELOPER GUIDE.pdf
80-NU767-1 G Linux BAM Low-Speed Peripherals Configuration and Debug Guide .pdf

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180214.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • (数据库)数据库分类

    (数据库)数据库分类1.面向操作的关系型数据库典型性应用领域:ERP,CRM,信用卡交易,中小型电商数据储存方法:表格流行厂商:OracleDatabase,MicrosoftSQLServer,IBMDB2,EnterpriseDB(PostgreSQL),MySQL优点:完善的生态环境保护,事务保证/数据一致性缺点:严苛的数据模型界定,数据库拓展限制,和非结构型的结合应用较难。2.面向数据分析的关系型数据库典型性应用领域:数据仓库,商务智能,数据科学研究数据储存方法:表格流行厂商:OracleE

    2022年6月24日
    34
  • 第二:Pycharm设置配置(非常详细)「建议收藏」

    第二:Pycharm设置配置(非常详细)「建议收藏」1、汉化:把resources_zh.jar拷贝到PyCharm的安装目录下的lib目录,重启Pycharm即可。(resources_zh.jar汉化包关注本账号获取:链接:https://pan.baidu.com/s/1JCpTloWnQdQ8ShsUt-Qabg提取码:i7pu)如果打开后显示乱码,请先删除resources_cn.jar,然后打开pycharm2017,在菜单上依次选择File->Settings->Appearance&Behavior

    2022年8月25日
    7
  • CIFAR-10 数据集「建议收藏」

    CIFAR-10 数据集「建议收藏」CIFAR-10数据集简介CIFAR-10是由Hinton的学生AlexKrizhevsky和IlyaSutskever整理的一个用于识别普适物体的小型数据集。一共包含10个类别的RGB彩色图片:飞机(a叩lane)、汽车(automobile)、鸟类(bird)、猫(cat)、鹿(deer)、狗(dog)、蛙类(frog)、马(hor…

    2022年4月19日
    40
  • idea tomcat catalina log乱码_xshell查看日志乱码怎么解决

    idea tomcat catalina log乱码_xshell查看日志乱码怎么解决以前一直使用Eclipse,现在试用IDEA,遇到一些坑,通过网上的答案基本都解决了,但有些答案不好,比如这个问题。1、原因分析Tomcat运行JavaWeb的程序,在IDEA控制台中输出显示,我们一般都是用UTF8编码。从Java源码到IDEA控制台,大致分为几个阶段:1)源码:即*.java原文件,是纯文本文件。编码方式在IDEA的Settings>Editor>FileEncodings中设置;2)…

    2022年9月26日
    2
  • 关于dos启动的一些知识

    关于dos启动的一些知识       最近装一个linux版本,就要用到dos,找来找去,忙乎了半天,又是缺文件,又是改配置。发现,一直用dos,但是还没有好好研究它。要研究dos,得从它的启动信息开始。。。。   一、DOS启动过程:开机->IO.SYS->MSDOS.SYS->CONFIG.SYS->COMMAND.COM->AUTOEXEC.BAT一般来说需要修改的是MSDOS.SYS、C

    2022年7月26日
    8
  • python进阶(15)多线程与多进程效率测试「建议收藏」

    python进阶(15)多线程与多进程效率测试「建议收藏」前言在Python中,计算密集型任务适用于多进程,IO密集型任务适用于多线程正常来讲,多线程要比多进程效率更高,因为进程间的切换需要的资源和开销更大,而线程相对更小,但是我们使用的Python大多

    2022年7月31日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号