提交 30eb3fbe 编写于 作者: A Alex Elder 提交者: Bjorn Andersson

net: ipa: new notification infrastructure

Use the new SSR notifier infrastructure to request notifications of
modem events, rather than the remoteproc IPA notification system.
The latter was put in place temporarily with the knowledge that the
new mechanism would become available.
Acked-by: NDavid S. Miller <davem@davemloft.net>
Reviewed-by: NBjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: NAlex Elder <elder@linaro.org>
Link: https://lore.kernel.org/r/20200724181142.13581-2-elder@linaro.orgSigned-off-by: NBjorn Andersson <bjorn.andersson@linaro.org>
上级 87218f96
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include <linux/device.h> #include <linux/device.h>
#include <linux/notifier.h> #include <linux/notifier.h>
#include <linux/pm_wakeup.h> #include <linux/pm_wakeup.h>
#include <linux/notifier.h>
#include "ipa_version.h" #include "ipa_version.h"
#include "gsi.h" #include "gsi.h"
...@@ -73,6 +74,8 @@ struct ipa { ...@@ -73,6 +74,8 @@ struct ipa {
enum ipa_version version; enum ipa_version version;
struct platform_device *pdev; struct platform_device *pdev;
struct rproc *modem_rproc; struct rproc *modem_rproc;
struct notifier_block nb;
void *notifier;
struct ipa_smp2p *smp2p; struct ipa_smp2p *smp2p;
struct ipa_clock *clock; struct ipa_clock *clock;
atomic_t suspend_ref; atomic_t suspend_ref;
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
#include <linux/netdevice.h> #include <linux/netdevice.h>
#include <linux/skbuff.h> #include <linux/skbuff.h>
#include <linux/if_rmnet.h> #include <linux/if_rmnet.h>
#include <linux/remoteproc/qcom_q6v5_ipa_notify.h> #include <linux/remoteproc/qcom_rproc.h>
#include "ipa.h" #include "ipa.h"
#include "ipa_data.h" #include "ipa_data.h"
...@@ -311,43 +311,40 @@ static void ipa_modem_crashed(struct ipa *ipa) ...@@ -311,43 +311,40 @@ static void ipa_modem_crashed(struct ipa *ipa)
dev_err(dev, "error %d zeroing modem memory regions\n", ret); dev_err(dev, "error %d zeroing modem memory regions\n", ret);
} }
static void ipa_modem_notify(void *data, enum qcom_rproc_event event) static int ipa_modem_notify(struct notifier_block *nb, unsigned long action,
void *data)
{ {
struct ipa *ipa = data; struct ipa *ipa = container_of(nb, struct ipa, nb);
struct device *dev; struct qcom_ssr_notify_data *notify_data = data;
struct device *dev = &ipa->pdev->dev;
dev = &ipa->pdev->dev; switch (action) {
switch (event) { case QCOM_SSR_BEFORE_POWERUP:
case MODEM_STARTING:
dev_info(dev, "received modem starting event\n"); dev_info(dev, "received modem starting event\n");
ipa_smp2p_notify_reset(ipa); ipa_smp2p_notify_reset(ipa);
break; break;
case MODEM_RUNNING: case QCOM_SSR_AFTER_POWERUP:
dev_info(dev, "received modem running event\n"); dev_info(dev, "received modem running event\n");
break; break;
case MODEM_STOPPING: case QCOM_SSR_BEFORE_SHUTDOWN:
case MODEM_CRASHED:
dev_info(dev, "received modem %s event\n", dev_info(dev, "received modem %s event\n",
event == MODEM_STOPPING ? "stopping" notify_data->crashed ? "crashed" : "stopping");
: "crashed");
if (ipa->setup_complete) if (ipa->setup_complete)
ipa_modem_crashed(ipa); ipa_modem_crashed(ipa);
break; break;
case MODEM_OFFLINE: case QCOM_SSR_AFTER_SHUTDOWN:
dev_info(dev, "received modem offline event\n"); dev_info(dev, "received modem offline event\n");
break; break;
case MODEM_REMOVING:
dev_info(dev, "received modem stopping event\n");
break;
default: default:
dev_err(&ipa->pdev->dev, "unrecognized event %u\n", event); dev_err(dev, "received unrecognized event %lu\n", action);
break; break;
} }
return NOTIFY_OK;
} }
int ipa_modem_init(struct ipa *ipa, bool modem_init) int ipa_modem_init(struct ipa *ipa, bool modem_init)
...@@ -362,13 +359,30 @@ void ipa_modem_exit(struct ipa *ipa) ...@@ -362,13 +359,30 @@ void ipa_modem_exit(struct ipa *ipa)
int ipa_modem_config(struct ipa *ipa) int ipa_modem_config(struct ipa *ipa)
{ {
return qcom_register_ipa_notify(ipa->modem_rproc, ipa_modem_notify, void *notifier;
ipa);
ipa->nb.notifier_call = ipa_modem_notify;
notifier = qcom_register_ssr_notifier("mpss", &ipa->nb);
if (IS_ERR(notifier))
return PTR_ERR(notifier);
ipa->notifier = notifier;
return 0;
} }
void ipa_modem_deconfig(struct ipa *ipa) void ipa_modem_deconfig(struct ipa *ipa)
{ {
qcom_deregister_ipa_notify(ipa->modem_rproc); struct device *dev = &ipa->pdev->dev;
int ret;
ret = qcom_unregister_ssr_notifier(ipa->notifier, &ipa->nb);
if (ret)
dev_err(dev, "error %d unregistering notifier", ret);
ipa->notifier = NULL;
memset(&ipa->nb, 0, sizeof(ipa->nb));
} }
int ipa_modem_setup(struct ipa *ipa) int ipa_modem_setup(struct ipa *ipa)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册