GPIO中断处理函数

本文介绍了Atheros AP83平台中GPIO中断处理的实现方式,通过注册回调函数来处理中断事件。示例代码展示了如何注册和注销中断处理函数,并在madwifi驱动中应用该机制来响应GPIO中断,触发特定网络操作。
摘要由CSDN通过智能技术生成

AtherosAP83的解决方案中,gpio的中断服务程序中设置了一个中断处理函数的入口,这个入口可以在其他方便的驱动程序中注册,就像一个钩子函数,感觉用法挺不错的,现在把它的框架记录下来。

int __init pbXX_simple_config_init(void)

{

    req = request_irq (AR7100_GPIO_IRQn(JUMPSTART_GPIO), jumpstart_irq, 0,

                       "SW JUMPSTART", NULL);

    return 0;

}

 

irqreturn_t jumpstart_irq(int cpl, void *dev_id, struct pt_regs *regs)

{

    printk ("calling simple_config callback..\n");

 

    if (registered_cb) {

        return registered_cb (cpl, cb_arg, regs);

    }

    return IRQ_HANDLED;

}

 

typedef irqreturn_t(*sc_callback_t)(int, void *, struct pt_regs *);

static sc_callback_t registered_cb = NULL;

static void *cb_arg;

 

void register_simple_config_callback (void *callback, void *arg)

{

    registered_cb = (sc_callback_t) callback;

    cb_arg = arg;

}

EXPORT_SYMBOL(register_simple_config_callback);

 

void unregister_simple_config_callback (void)

{

    registered_cb = NULL;

    cb_arg = NULL;

}

EXPORT_SYMBOL(unregister_simple_config_callback);

 

In madwifi driver

    /* Request Simple Config intr handler */

    register_simple_config_callback ((void *) jumpstart_intr, (void *) dev);

 

 

/*

 * Handler for front panel SW jumpstart switch

 */

static irqreturn_t

jumpstart_intr (int cpl, void *dev_id, struct pt_regs *regs)

{

    struct net_device *dev = dev_id;

    struct ath_softc_net80211 *scn = dev->priv;

    struct ieee80211com *ic = &scn->sc_ic;

    struct ieee80211vap *vap;

 

    vap = TAILQ_FIRST(&ic->ic_vaps);

    if (vap != NULL) {

        ieee80211_notify_push_button (vap);

    }

    return IRQ_HANDLED;

}

 

这个函数就是这个GPIO中断最后对应的处理函数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值