QCC30XX如何查找本地地址码
查找本地地址段/**********************************************************************
Copyright (c) 2016 - 2017 Qualcomm Technologies International, Ltd.
FILE NAME
sink_private_data.c
DESCRIPTION
This module works as a container for all private and common data that is used across sink
qpplication. It provides API to access the data from outside. It interacts with configuration
entities to read/write configuration data. More over this module contains module specific
run time data (as a common runtime data for entire sink application), and those data also
exposed using defined API's
NOTES
Module does not have any intelligence to manipulate the data, or verify the data or its
contents ,it is the user to decide hoe to use this data and when to update the data.
*/
#include <stdlib.h>
#include <ps.h>
#include <vmtypes.h>
#include <bdaddr.h>
#include <byte_utils.h>
#include "sink_private_data.h"
#include "sink_dut.h"
#include "sink_malloc_debug.h"
#include "sink_configmanager.h"
#include <local_device.h>
#ifdef DEBUG_SINK_PRIVATE_DATA
#define SINK_DATA_DEBUG(x) DEBUG(x)
#define SINK_DATA_ERROR(x) TOLERATED_ERROR(x)
#else
#define SINK_DATA_DEBUG(x)
#define SINK_DATA_ERROR(x)
#endif
#ifdef DEBUG_MAIN
#define MAIN_DEBUG(x) DEBUG(x)
#else
#define MAIN_DEBUG(x)
#endif
/* Referance to Global Data for sink private module */
typedef struct __sinkdata_globaldata_t
{
unsigned panic_reconnect:1; /* Are we using panic action? Bit to inidcate panic reconnection action is used */
unsigned paging_in_progress:1; /* Bit to indicate that device is curretly paging whilst in connectable state*/
unsigned powerup_no_connection:1; /* Bit to indicate device has powered and no connections yet */
unsigned confirmation:1; /* Bit to indicate user auth confirmation status */
unsigned SinkInitialising:1; /* Bit to indicate sink is in initialising state */
unsigned PowerOffIsEnabled:1; /* Bit to indicate power off is enabled */
unsigned debug_keys_enabled:1; /* Bit to indicate debug keys enabled */
unsigned stream_protection_state:2; /* Holds stream protection state */
unsigned MultipointEnable:1; /* Bit to indicate multipoint enabled */
unsigned _spare1_:6;
unsigned gEventQueuedOnConnection:8; /* variable to hold evet queued while in connection */
unsigned dfu_access:1; /* Link Policy expedites DFU data transfer */
unsigned display_link_keys:1; /* Bit used to indicate if link keys should be displayed */
unsigned _spare2_:6;
uint16 NoOfReconnectionAttempts; /* Holdes current number of reconnection attempts */
uint16 connection_in_progress; /* flag used to block role switch requests until all connections are complete or abandoned */
#ifdef ENABLE_SQIFVP
unsigned partitions_mounted:8;
unsigned unused:8;
#endif
bdaddr *linkloss_bd_addr; /** bdaddr of a2dp device that had the last link loss. */
tp_bdaddr *confirmation_addr;
bdaddr local_bd_addr; /* Local BD Address of the sink device available in ps */
power_table *user_power_table; /* pointer to user power table if available in ps */
}sinkdata_globaldata_t;
/* PSKEY for BD ADDRESS */
#define PSKEY_BDADDR 0x0001
#define LAP_MSW_OFFSET 0
#define LAP_LSW_OFFSET 1
#define UAP_OFFSET 2
#define NAP_OFFSET 3
/* Global data strcuture element for sink private data */
static sinkdata_globaldata_t gSinkData;
#define GSINKDATA gSinkData
/**********************************************************************
*************** External Interface Function Implemetations **********************
***********************************************************************/
/**********************************************************************
Interfaces for accessing Configurable Items
*/
/**********************************************************************
Interfaces for Initializing Local Address, which read the local address.
*/
bool sinkDataInitLocalBdAddrFromPs(void)
{
bool result = FALSE;
uint16 size = PS_SIZE_ADJ(sizeof(GSINKDATA.local_bd_addr));
uint16* bd_addr_data = (uint16*)PanicUnlessNew(bdaddr);
BdaddrSetZero(&GSINKDATA.local_bd_addr);
if(size == PsFullRetrieve(PSKEY_BDADDR, bd_addr_data, size))
{
GSINKDATA.local_bd_addr.nap = bd_addr_data[NAP_OFFSET];
GSINKDATA.local_bd_addr.uap = bd_addr_data[UAP_OFFSET];
GSINKDATA.local_bd_addr.lap = MAKELONG(bd_addr_data[LAP_LSW_OFFSET], bd_addr_data[LAP_MSW_OFFSET]);
SINK_DATA_DEBUG(("CONF: PSKEY_BDADDR [%04x %02x %06lx]\n",
GSINKDATA.local_bd_addr.nap, GSINKDATA.local_bd_addr.uap, GSINKDATA.local_bd_addr.lap));
result = TRUE;
}
else
{
GSINKDATA.local_bd_addr = LocalDeviceGetBdAddr();
}
MAIN_DEBUG(("CONF: PSKEY_BDADDR [%04x %02x %06lx]\n",
GSINKDATA.local_bd_addr.nap, GSINKDATA.local_bd_addr.uap, GSINKDATA.local_bd_addr.lap));
free(bd_addr_data);
return result;
}
/**********************************************************************
Interfaces for checking reconnect on panic configuration is enabled or not
*/
bool sinkDataIsReconnectOnPanic(void)
{
bool reconnect_on_panic = FALSE;
sinkdata_readonly_config_def_t *read_configdata = NULL;
SINK_DATA_DEBUG(("SinkData:sinkDataIsReconnectOnPanic()\n"));
if (configManagerGetReadOnlyConfig(SINKDATA_READONLY_CONFIG_BLK_ID, (const void **)&read_configdata))
{
reconnect_on_panic = read_configdata->ReconnectOnPanic;
configManagerReleaseConfig(SINKDATA_READONLY_CONFIG_BLK_ID);
}
SINK_DATA_DEBUG(("SinkData:reconnect_on_panic = %d \n",reconnect_on_panic));
return (reconnect_on_panic)?TRUE : FALSE;
}
/**********************************************************************
Interfaces for checking power of after PDL reset configuration is enabled or not
*/
bool sinkDataIsPowerOffAfterPDLReset(void)
{
bool poweroff_pdl_reset = FALSE;
sinkdata_readonly_config_def_t *read_configdata = NULL;
SINK_DATA_DEBUG(("SinkData:sinkDataIsPowerOffAfterPDLReset()\n"));
if (configManagerGetReadOnlyConfig(SINKDATA_READONLY_CONFIG_BLK_ID, (const void **)&read_configdata))
{
poweroff_pdl_reset = read_configdata->PowerOffAfterPDLReset;
configManagerReleaseConfig(SINKDATA_READONLY_CONFIG_BLK_ID);
}
SINK_DATA_DEBUG(("SinkData: poweroff_pdl_reset = %d \n",poweroff_pdl_reset));
return (poweroff_pdl_reset)?TRUE : FALSE;
}
/**********************************************************************
Interfaces for checking does sink shoule be in discoverable mode all time
configuration is enabled or not
*/
bool sinkDataIsDiscoverableAtAllTimes(void)
{
bool discoverable_alltime = FALSE;
sinkdata_readonly_config_def_t *read_configdata = NULL;
SINK_DATA_DEBUG(("SinkData:sinkDataIsDiscoverableAtAllTimes()\n"));
if (configManagerGetReadOnlyConfig(SINKDATA_READONLY_CONFIG_BLK_ID, (const void **)&read_configdata))
{
discoverable_alltime = read_configdata->RemainDiscoverableAtAllTimes;
configManagerReleaseConfig(SINKDATA_READONLY_CONFIG_BLK_ID);
}
SINK_DATA_DEBUG(("SinkData: discoverable_alltime = %d\n",discoverable_alltime));
return (discoverable_alltime)?TRUE : FALSE;
}
/**********************************************************************
Interfaces for checking DisablePowerOffAfterPowerOn configuration is enabled or not
*/
bool sinkDataCheckDisablePowerOffAfterPowerOn(void)
{
bool disable_poweroff = FALSE;
sinkdata_readonly_config_def_t *read_configdata = NULL;
SINK_DATA_DEBUG(("SinkData:sinkDataCheckDisablePowerOffAfterPowerOn()\n"));
if (configManagerGetReadOnlyConfig(SINKDATA_READONLY_CONFIG_BLK_ID, (const void **)&read_configdata))
{
disable_poweroff = read_configdata->DisablePowerOffAfterPowerOn;
configManagerReleaseConfig(SINKDATA_READONLY_CONFIG_BLK_ID);
}
SINK_DATA_DEBUG(("SinkData: disable_poweroff = %d\n",disable_poweroff));
return (disable_poweroff)?TRUE : FALSE;
}
/**********************************************************************
Interfaces for checking pairing mode on connection failure configuration is enabled or not
*/
bool sinkDataEntrePairingModeOnConFailure(void)
{
bool failuretoconnect = FALSE;
sinkdata_readonly_config_def_t *read_configdata = NULL;
SINK_DATA_DEBUG(("SinkData:sinkDataPairingModeOnConnectionFailure()\n"));
if (configManagerGetReadOnlyConfig(SINKDATA_READONLY_CONFIG_BLK_ID, (const void **)&read_configdata))
{
failuretoconnect = read_configdata->EnterPairingModeOnFailureToConn;
configManagerReleaseConfig(SINKDATA_READONLY_CONFIG_BLK_ID);
}
SINK_DATA_DEBUG(("SinkData: failuretoconnect = %d\n",failuretoconnect));
return (failuretoconnect)?TRUE : FALSE;
}
/**********************************************************************
Interfaces for checking Power Off OnlyIf VReg Enble is low configuration is enabled or not
*/
bool sinkDataIsPowerOffOnlyIfVRegEnlow(void)
{
bool vreg_enlow = FALSE;
sinkdata_readonly_config_def_t *read_configdata = NULL;
SINK_DATA_DEBUG(("SinkData:sinkDataIsPowerOffOnlyIfVRegEnlow()\n"));
if (configManagerGetReadOnlyConfig(SINKDATA_READONLY_CONFIG_BLK_ID, (const void **)&read_configdata))
{
vreg_enlow = read_configdata->PowerOffOnlyIfVRegEnLow;
configManagerReleaseConfig(SINKDATA_READONLY_CONFIG_BLK_ID);
}
SINK_DATA_DEBUG(("SinkData: vreg_enlow = %d\n",vreg_enlow));
return (vreg_enlow)?TRUE : FALSE;
}
/**********************************************************************/
bool sinkDataAllowAutomaticPowerOffWhenCharging(void)
{
bool power_off_when_charging = FALSE;
sinkdata_readonly_config_def_t *read_configdata = NULL;
SINK_DATA_DEBUG(("SinkData:sinkDataAllowAutomaticPowerOffWhenCharging()\n"));
if (configManagerGetReadOnlyConfig(SINKDATA_READONLY_CONFIG_BLK_ID, (const void **)&read_configdata))
{
power_off_when_charging = read_configdata->AllowAutomaticPowerOffWhenCharging;
configManagerReleaseC
相关文章:
QCC30XX如何查找本地地址码
查找本地地址段/********************************************************************** Copyright (c) 2016 - 2017 Qualcomm Technologies International, Ltd. FILE NAME sink_private_data.c DESCRIPTION This module works as a container for all private and common…...
基于 DCT 的图像滤波
需求分析 对于图像去噪这一需求,我们可以通过DCT(离散余弦变换)算法来实现。DCT是一种基于频域的变换技术,可以将图像从空间域转换为频域,然后通过滤波等处理方式进行去噪。 针对这一需求,我们需要进行以下…...
spdlog日志库源码:自定义异常类spdlog_ex
自定义异常类spdlog_ex 标准库异常类(std::exception)系列,能满足大多数使用异常的场景,但对系统调用异常及错误信息缺乏支持。spdlog通过继承std::exception,扩展对系统调用的支持,实现自定义异常类spdlo…...
3.每日LeetCode-数组类,爬楼梯(Go,Java,Python)
目录 题目 解法 Go Java Python 代码地址:leetcode: 每日leetcode刷题 题目 题号70. 爬楼梯 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 示例 1: 输入ÿ…...
单节点11.2.0.3参数文件恢复到RAC11.2.0.4启动失败
问题描述 通过pfile生成spfile失败,提示DATA磁盘不存在 SQL> create spfileDATA/DXJ/spfiledxj.ora from pfile/home/oracle/initdxj20240529.ora; create spfileDATA/DXJ/spfiledxj.ora from pfile/home/oracle/initdxj20240529.ora * ERROR at line 1: ORA-1…...
Windows电脑高颜值桌面便利贴,便签怎么设置
在这个看颜值的时代,我们不仅在衣着打扮上追求时尚与美观,就连电脑桌面也不愿放过。一张唯美的壁纸,几款别致的小工具,总能让我们的工作空间焕发出不一样的光彩。如果你也热衷于打造高颜值的电脑桌面,那么,…...
代码随想录35期Day54-Java
Day54题目 LeetCode392判断子序列 核心思想:公共子序列长度达到需要判断的字符串的长度,说明是子序列 class Solution {public boolean isSubsequence(String s, String t) {if("".equals(s)) return true;int[][] dp new int[s.length()1][t.length()1];for(int…...
Ubuntu使用sudo命令
在Ubuntu系统中,使用管理员权限通常涉及到使用sudo命令。这是因为Ubuntu默认情况下不直接允许root用户登录,而是通过sudo命令来执行需要管理员权限的任务。以下是一些常见的使用管理员权限的方法: 1. 使用sudo命令 运行单个命令 如果只需要…...
三方语言中调用, Go Energy GUI编译的dll动态链接库CEF
如何在其它编程语言中调用energy编译的dll动态链接库,以使用CEF 或 LCL库 Energy是Go语言基于LCL CEF开发的跨平台GUI框架, 具有很容易使用CEF 和 LCL控件库 interface 便利 示例链接 正文 为方便起见使用 python 调用 go energy 编译的dll 准备 系统&#x…...
Go微服务: Grpc服务注册在Consul的示例(非Go-Micro)
概述 现在,我们使用consul客户端的api来把GRPC服务实现注册到consul上,非Go-Micro的形式其实,consul官方提供了对应的接口调用来实现,golang中的consul/api包对其进行了封装我们使用consul/api来进行展示 目录结构 gitee.com/g…...
Java+Swing+Mysql实现飞机订票系统
一、系统介绍 1.开发环境 操作系统:Win10 开发工具 :Eclipse2021 JDK版本:jdk1.8 数据库:Mysql8.0 2.技术选型 JavaSwingMysql 3.功能模块 4.数据库设计 1.用户表(users) 字段名称 类型 记录内容…...
2024 rk
1.mysql、redis分布式锁 case: 商品秒杀 1)使用 MySQL 作为分布式锁来实现商品秒杀功能可能存在以下几个缺点; 使用 MySQL 作为分布式锁来实现商品秒杀功能可能存在以下几个缺点: 单点故障:如果使用单个 MySQL 实例作为分布式锁的存储介质…...
Java实现多张图片合并保存到pdf中
Java实现多张图片合并保存到pdf中 1、依赖–maven <dependency><groupId>org.apache.pdfbox</groupId><artifactId>pdfbox</artifactId><version>2.0.24</version></dependency>2、上代码 package com.hxlinks.hxiot.contro…...
揭秘智慧校园:可视化技术引领教育新篇章
随着科技的飞速发展,我们的生活方式正在经历一场前所未有的变革。而在这场变革中,学校作为培养未来人才的重要基地,也在不断地探索与创新。 一、什么是校园可视化? 校园可视化,就是通过先进的信息技术,将学…...
基础9 探索图形化编程的奥秘:从物联网到工业自动化
办公室内,明媚的阳光透过窗户洒落,为每张办公桌披上了一层金色的光辉。同事们各自忙碌着,键盘敲击声、文件翻页声和低声讨论交织在一起,营造出一种忙碌而有序的氛围。空气中氤氲着淡淡的咖啡香气和纸张的清新味道,令人…...
RPC-----RCF
RPC RPC(Remote Procedure Call Protocol)——远程过程调用协议。 RCF...
StarRocks中,这些配置项是表属性的一部分
CREATE TABLE warehouse.ads_order_all_df ( so_id varchar(200) NULL COMMENT "销售订单主表标识", so_code varchar(200) NULL COMMENT "销售订单主表表号" ) ENGINEOLAP DUPLICATE KEY(so_id) COMMENT "OLAP" DISTRIBUTED BY HASH(dt) …...
Activity->Activity生命周期
<四大组件 android:name"xxx"android:exported"true" // 该组边能够被其他组件启动android:enabled"true" // 该组件能工与用户交互 </四大组件>Activity常用生命周期 启动Activity 2024-05-29 03:53:57.401 21372-21372 yang …...
乐鑫ESP串口驱动安装,安装cp210x驱动
windows11安装cp210x驱动: 1:第一步官网下载驱动: 官网地址如下: CP210x USB to UART Bridge VCP Drivers - Silicon Labs 第二步:解压文件夹并安装如图所示: 3:第三步安装成功后会给你个提示…...
Django缓存
由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显,最简单解决方式是使用:缓存,缓存将一个某个views的返回值保存至内存或者memcache中,若某个时…...
Docker 离线安装指南
参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性,不同版本的Docker对内核版本有不同要求。例如,Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本,Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...
java_网络服务相关_gateway_nacos_feign区别联系
1. spring-cloud-starter-gateway 作用:作为微服务架构的网关,统一入口,处理所有外部请求。 核心能力: 路由转发(基于路径、服务名等)过滤器(鉴权、限流、日志、Header 处理)支持负…...
通过Wrangler CLI在worker中创建数据库和表
官方使用文档:Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后,会在本地和远程创建数据库: npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库: 现在,您的Cloudfla…...
React19源码系列之 事件插件系统
事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...
解决本地部署 SmolVLM2 大语言模型运行 flash-attn 报错
出现的问题 安装 flash-attn 会一直卡在 build 那一步或者运行报错 解决办法 是因为你安装的 flash-attn 版本没有对应上,所以报错,到 https://github.com/Dao-AILab/flash-attention/releases 下载对应版本,cu、torch、cp 的版本一定要对…...
【碎碎念】宝可梦 Mesh GO : 基于MESH网络的口袋妖怪 宝可梦GO游戏自组网系统
目录 游戏说明《宝可梦 Mesh GO》 —— 局域宝可梦探索Pokmon GO 类游戏核心理念应用场景Mesh 特性 宝可梦玩法融合设计游戏构想要素1. 地图探索(基于物理空间 广播范围)2. 野生宝可梦生成与广播3. 对战系统4. 道具与通信5. 延伸玩法 安全性设计 技术选…...
深度学习习题2
1.如果增加神经网络的宽度,精确度会增加到一个特定阈值后,便开始降低。造成这一现象的可能原因是什么? A、即使增加卷积核的数量,只有少部分的核会被用作预测 B、当卷积核数量增加时,神经网络的预测能力会降低 C、当卷…...
Spring是如何解决Bean的循环依赖:三级缓存机制
1、什么是 Bean 的循环依赖 在 Spring框架中,Bean 的循环依赖是指多个 Bean 之间互相持有对方引用,形成闭环依赖关系的现象。 多个 Bean 的依赖关系构成环形链路,例如: 双向依赖:Bean A 依赖 Bean B,同时 Bean B 也依赖 Bean A(A↔B)。链条循环: Bean A → Bean…...
Mysql中select查询语句的执行过程
目录 1、介绍 1.1、组件介绍 1.2、Sql执行顺序 2、执行流程 2.1. 连接与认证 2.2. 查询缓存 2.3. 语法解析(Parser) 2.4、执行sql 1. 预处理(Preprocessor) 2. 查询优化器(Optimizer) 3. 执行器…...
MySQL的pymysql操作
本章是MySQL的最后一章,MySQL到此完结,下一站Hadoop!!! 这章很简单,完整代码在最后,详细讲解之前python课程里面也有,感兴趣的可以往前找一下 一、查询操作 我们需要打开pycharm …...
