首页专栏详情
打赏
T31如何获取ATBM6441唤醒事件
T31如何获取ATBM6441唤醒事件
易百纳技术社区 冰糖炖雪梨 2022-11-11 11:41:24

ATBM6441 SDK修改:

1,初始化GPIO,并设置为中断。

2,中断触发唤醒,

wakeup_host_reason = WAKEUP_TYPE_PIR; //WAKEUP_TYPE_CONNECT

HI_WakeupBT_Process(Wakeup_Gpio_Data_Get(),0);

T31则WiFi 驱动修改:

Index: hal_apollo/atbm_ioctl_ext.h

===================================================================

--- hal_apollo/atbm_ioctl_ext.h (revision 1850)

+++ hal_apollo/atbm_ioctl_ext.h (revision 1851)

@@ -1,7 +1,7 @@

#ifndef ATBM_IOCTL_EXT_H

#define ATBM_IOCTL_EXT_H

-#define PRIV_VERSION  "2020-1125-1825"

+#define PRIV_VERSION  "2020-1208-1347"

#define ATBM_IOCTL          (121)

Index: hal_apollo/main.c

===================================================================

--- hal_apollo/main.c (revision 1850)

+++ hal_apollo/main.c (revision 1851)

@@ -144,7 +144,8 @@

mutex_lock(&hw_priv->conf_mutex);

list_for_each_entry(event, &list, link) {

if ((event->evt.eventId != WSM_EVENT_HOST_RMMOD)

- && (event->evt.eventId != WSM_EVENT_HOST_INSMOD)){

+ && (event->evt.eventId != WSM_EVENT_HOST_INSMOD)

+ && (event->evt.eventId != WSM_EVENT_HOST_WAKEUP_REASON)){

priv = __ABwifi_hwpriv_to_vifpriv(hw_priv, event->if_id);

if (!priv) {

printk( "[CQM] Event for non existing interface, ignoring.\n");

@@ -219,6 +220,12 @@

atbm_ioctl_driver_async(1);

break;

}

+ case WSM_EVENT_HOST_WAKEUP_REASON:

+ {

+ u8 reason = *((u8 *)event->evt.buffer);

+ atbm_ioctl_wakeup_async(reason);

+ break;

+ }

}

}

mutex_unlock(&hw_priv->conf_mutex);

Index: hal_apollo/wsm.c

===================================================================

--- hal_apollo/wsm.c (revision 1850)

+++ hal_apollo/wsm.c (revision 1851)

@@ -208,7 +208,8 @@

eventid=__le32_to_cpu(WSM_GET32(buf));

if ((eventid != WSM_EVENT_HOST_RMMOD)

- && (eventid != WSM_EVENT_HOST_INSMOD)){

+ && (eventid != WSM_EVENT_HOST_INSMOD)

+ && (eventid != WSM_EVENT_HOST_WAKEUP_REASON)){

priv = ABwifi_hwpriv_to_vifpriv(hw_priv, interface_link_id);

if (unlikely(!priv)) {

Index: hal_apollo/wsm.h

===================================================================

--- hal_apollo/wsm.h (revision 1850)

+++ hal_apollo/wsm.h (revision 1851)

@@ -422,6 +422,9 @@

/*HOST insmod*/

#define WSM_EVENT_HOST_INSMOD (11)

+/*HOST wakeup reason*/

+#define WSM_EVENT_HOST_WAKEUP_REASON (12)

+

/* MAC Addr Filter */

#define WSM_MIB_ID_MAC_ADDR_FILTER 0x1030

Index: hal_apollo/atbm_ioctl.c

===================================================================

--- hal_apollo/atbm_ioctl.c (revision 1850)

+++ hal_apollo/atbm_ioctl.c (revision 1851)

@@ -24,7 +24,7 @@

struct status_async{

u8 is_connected;

- u8 type; /* 0: connect msg, 1: driver msg, 2:scan complete*/

+ u8 type; /* 0: connect msg, 1: driver msg, 2:scan complete, 3:wakeup host reason*/

u8 driver_mode; /* 0: rmmod, 1: insmod*/

u8 reserved[1];

struct HostConnectEvent event;

@@ -70,6 +70,13 @@

kill_fasync (&connect_async, SIGIO, POLL_IN);

}

+void atbm_ioctl_wakeup_async(int reason)

+{

+ status.type = 3;

+ status.driver_mode = reason;

+ kill_fasync (&connect_async, SIGIO, POLL_IN);

+}

+

static int atbm_wsm_ps(struct atbm_common *hw_priv, unsigned int data)

{

int ret = 0;

Index: hal_apollo/atbm_ioctl.h

===================================================================

--- hal_apollo/atbm_ioctl.h (revision 1850)

+++ hal_apollo/atbm_ioctl.h (revision 1851)

@@ -14,6 +14,7 @@

void atbm_ioctl_connect_async(struct HostConnectEvent *event, char is_connected);

void atbm_ioctl_driver_async(int insmod);

+void atbm_ioctl_wakeup_async(int reason);

int atbm_ioctl_add(void);

void atbm_ioctl_free(void);

Index: tools/atbm_tool.h

===================================================================

--- tools/atbm_tool.h (revision 1850)

+++ tools/atbm_tool.h (revision 1851)

@@ -269,7 +269,7 @@

struct status_async{

u8 is_connected;

- u8 type; /*0: connect msg; 1: rmmod; 2: scan complete*/

+ u8 type; /*0: connect msg; 1: rmmod; 2: scan complet, 3:wakeup host reasone*/

u8 driver_mode; /* 0: rmmod, 1: insmod*/

u8 reserved[1];

struct HostConnectEvent event;

@@ -351,6 +351,12 @@

CHECK_MAX

}check_type;

+enum{

+ WAKEUP_IO,

+ WAKEUP_NETWORK,

+ WAKEUP_CONNECT,

+ WAKEUP_KEEPALIVE

+};

#endif /* ATBM_TOOL_H */

Index: tools/tools.c

===================================================================

--- tools/tools.c (revision 1850)

+++ tools/tools.c (revision 1851)

@@ -2290,6 +2290,26 @@

printf("Scan Completed...\n");

printf("CTRL-EVENT-SCAN-RESULTS\n");

}

+ else if (status.type == 3)

+ {

+ switch (status.driver_mode){

+ case WAKEUP_IO:

+ printf("IO wakeup\n");

+ break;

+ case WAKEUP_NETWORK:

+ printf("NETWORK wakeup\n");

+ break;

+ case WAKEUP_CONNECT:

+ printf("AP RECONNECT wakeup\n");

+ break;

+ case WAKEUP_KEEPALIVE:

+ printf("KEEPALIVE wakeup\n");

+ break;

+ default:

+ printf("UNKNOWN wakeup\n");

+ break;

+ }

+ }

}

sem_post(&sem_status);



声明:本文内容由易百纳平台入驻作者撰写,文章观点仅代表作者本人,不代表易百纳立场。如有内容侵权或者其他问题,请联系本站进行删除。

514
收藏
点赞
打赏
给作者打赏,鼓励他抓紧创作吧~
评论
0个
内容存在敏感词
相关专栏
打赏作者
易百纳技术社区
冰糖炖雪梨
您的支持将鼓励我继续创作!
打赏金额:
¥1 易百纳技术社区
¥5 易百纳技术社区
¥10 易百纳技术社区
¥50 易百纳技术社区
¥100 易百纳技术社区
支付方式:
微信支付
支付宝支付
易百纳技术社区 微信支付
易百纳技术社区
打赏成功!

感谢您的打赏,如若您也想被打赏,可前往 发表专栏 哦~

审核成功

发布时间设置
发布时间:
是否关联周任务-专栏模块

审核失败

失败原因
备注
Loading...
易百纳技术社区
确定要删除此文章、专栏、评论吗?
确定
取消
易百纳技术社区
易百纳技术社区
在专栏模块发布专栏,可获得其他E友的打赏
易百纳技术社区
回答悬赏问答,被题主采纳后即可获得悬赏金
易百纳技术社区
在上传资料时,有价值的资料可设置为付费资源
易百纳技术社区
达到一定金额,收益即可提现~
收益也可用来充值ebc,下载资料、兑换礼品更容易
易百纳技术社区
活动规则
  • 1.周任务为周期性任务,每周周一00:00刷新,上周完成的任务不会累计到本周,本周需要从头开始任务,当前任务完成后才可以完成下一个任务
  • 2.发布的专栏与资料需要与平台的板块有相关性,禁止注水,专栏/资料任务以审核通过的篇数为准
  • 3.任务完成后,现金奖励直接打款到微信账户;EBC/收益将自动发放到个人账户,可前往“我的钱包”查看;其他奖励请联系客服兑换
  • 4.每周最后三个任务将会有以下奖品掉落:社区热卖开发板、小米音响、视频年度会员、京东卡、华为手机等等
易百纳技术社区
升级提醒
易百纳技术社区

恭喜您由入门

社区送出礼品一份

请填写您的收件地址,礼品将在3个工作日寄出

易百纳技术社区