From patchwork Thu Jul 28 07:55:10 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Daniel Wagner X-Patchwork-Id: 9250817 X-Patchwork-Delegate: kvalo@adurom.com Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id 6075F6077C for ; Thu, 28 Jul 2016 08:05:50 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 539FF212DA for ; Thu, 28 Jul 2016 08:05:50 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 4859926253; Thu, 28 Jul 2016 08:05:50 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.9 required=2.0 tests=BAYES_00,RCVD_IN_DNSWL_HI autolearn=unavailable version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id E00D1212DA for ; Thu, 28 Jul 2016 08:05:49 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758482AbcG1IFs (ORCPT ); Thu, 28 Jul 2016 04:05:48 -0400 Received: from hotel311.server4you.de ([85.25.146.15]:52494 "EHLO hotel311.server4you.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753642AbcG1IFa (ORCPT ); Thu, 28 Jul 2016 04:05:30 -0400 Received: from hotel311.server4you.de (localhost [127.0.0.1]) by filter.mynetwork.local (Postfix) with ESMTP id EE34F1941A6D; Thu, 28 Jul 2016 09:55:29 +0200 (CEST) Received: from localhost (unknown [212.118.206.70]) by hotel311.server4you.de (Postfix) with ESMTPSA id CCDBB1941A87; Thu, 28 Jul 2016 09:55:29 +0200 (CEST) From: Daniel Wagner To: Bastien Nocera , Bjorn Andersson , Dmitry Torokhov , Greg Kroah-Hartman , Johannes Berg , Kalle Valo , Ohad Ben-Cohen Cc: linux-input@vger.kernel.org, linux-kselftest@vger.kernel.org, linux-wireless@vger.kernel.org, linux-kernel@vger.kernel.org, Daniel Wagner Subject: [RFC v0 6/8] remoteproc: use firmware_stat instead of completion Date: Thu, 28 Jul 2016 09:55:10 +0200 Message-Id: <1469692512-16863-7-git-send-email-wagi@monom.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1469692512-16863-1-git-send-email-wagi@monom.org> References: <1469692512-16863-1-git-send-email-wagi@monom.org> Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP From: Daniel Wagner Loading firmware is an operation many drivers implement in various ways around the completion API. And most of them do it almost in the same way. Let's reuse the firmware_stat API which is used also by the firmware_class loader. Apart of streamlining the firmware loading states we also document it slightly better. Signed-off-by: Daniel Wagner --- drivers/remoteproc/remoteproc_core.c | 10 +++++----- drivers/soc/ti/wkup_m3_ipc.c | 2 +- include/linux/remoteproc.h | 6 ++++-- 3 files changed, 10 insertions(+), 8 deletions(-) diff --git a/drivers/remoteproc/remoteproc_core.c b/drivers/remoteproc/remoteproc_core.c index db3958b..3b158f7 100644 --- a/drivers/remoteproc/remoteproc_core.c +++ b/drivers/remoteproc/remoteproc_core.c @@ -936,7 +936,7 @@ static void rproc_fw_config_virtio(const struct firmware *fw, void *context) out: release_firmware(fw); /* allow rproc_del() contexts, if any, to proceed */ - complete_all(&rproc->firmware_loading_complete); + fw_loading_done(rproc->fw_st); } static int rproc_add_virtio_devices(struct rproc *rproc) @@ -944,7 +944,7 @@ static int rproc_add_virtio_devices(struct rproc *rproc) int ret; /* rproc_del() calls must wait until async loader completes */ - init_completion(&rproc->firmware_loading_complete); + firmware_stat_init(&rproc->fw_st); /* * We must retrieve early virtio configuration info from @@ -959,7 +959,7 @@ static int rproc_add_virtio_devices(struct rproc *rproc) rproc, rproc_fw_config_virtio); if (ret < 0) { dev_err(&rproc->dev, "request_firmware_nowait err: %d\n", ret); - complete_all(&rproc->firmware_loading_complete); + fw_loading_abort(rproc->fw_st); } return ret; @@ -1089,7 +1089,7 @@ static int __rproc_boot(struct rproc *rproc, bool wait) /* if rproc virtio is not yet configured, wait */ if (wait) - wait_for_completion(&rproc->firmware_loading_complete); + fw_loading_wait(rproc->fw_st); ret = rproc_fw_boot(rproc, firmware_p); @@ -1447,7 +1447,7 @@ int rproc_del(struct rproc *rproc) return -EINVAL; /* if rproc is just being registered, wait */ - wait_for_completion(&rproc->firmware_loading_complete); + fw_loading_wait(rproc->fw_st); /* clean up remote vdev entries */ list_for_each_entry_safe(rvdev, tmp, &rproc->rvdevs, node) diff --git a/drivers/soc/ti/wkup_m3_ipc.c b/drivers/soc/ti/wkup_m3_ipc.c index 8823cc8..14c6396 100644 --- a/drivers/soc/ti/wkup_m3_ipc.c +++ b/drivers/soc/ti/wkup_m3_ipc.c @@ -370,7 +370,7 @@ static void wkup_m3_rproc_boot_thread(struct wkup_m3_ipc *m3_ipc) struct device *dev = m3_ipc->dev; int ret; - wait_for_completion(&m3_ipc->rproc->firmware_loading_complete); + fw_loading_wait(m3_ipc->rproc->fw_st); init_completion(&m3_ipc->sync_complete); diff --git a/include/linux/remoteproc.h b/include/linux/remoteproc.h index 1c457a8..b8e7ff4 100644 --- a/include/linux/remoteproc.h +++ b/include/linux/remoteproc.h @@ -41,6 +41,7 @@ #include #include #include +#include /** * struct resource_table - firmware resource table header @@ -397,7 +398,7 @@ enum rproc_crash_type { * @num_traces: number of trace buffers * @carveouts: list of physically contiguous memory allocations * @mappings: list of iommu mappings we initiated, needed on shutdown - * @firmware_loading_complete: marks e/o asynchronous firmware loading + * @fw_sync: marks e/o asynchronous firmware loading * @bootaddr: address of first instruction to boot rproc with (optional) * @rvdevs: list of remote virtio devices * @notifyids: idr for dynamically assigning rproc-wide unique notify ids @@ -429,7 +430,7 @@ struct rproc { int num_traces; struct list_head carveouts; struct list_head mappings; - struct completion firmware_loading_complete; + struct firmware_stat fw_st; u32 bootaddr; struct list_head rvdevs; struct idr notifyids; @@ -479,6 +480,7 @@ struct rproc_vring { * @vring: the vrings for this vdev * @rsc_offset: offset of the vdev's resource entry */ + struct rproc_vdev { struct list_head node; struct rproc *rproc;