Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp802258ybl; Fri, 13 Dec 2019 04:58:43 -0800 (PST) X-Google-Smtp-Source: APXvYqwv6DGHf/6hRkeBtwt7e5S9DAgZ6Sh3vzcqNBG/o9TyJojmlHf5tgBQCYybwK5sweelWnNS X-Received: by 2002:a05:6830:1289:: with SMTP id z9mr15004167otp.317.1576241923490; Fri, 13 Dec 2019 04:58:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576241923; cv=none; d=google.com; s=arc-20160816; b=gE6uuBp+iiHRe+Pz+GftWJIx5iLjHyhlSmRH2sTGzoX8uqsg3Wf18d8jsifYmcHbG6 NkFvwVs87GmGYXW++NdaBVHbeTlfIx95gWNAkhFlgJkjb9a76e50c1kMwbnacuAckjKA 7Xt8ROH/kQSUMXdqbO8KZzHFe3no8hsSsQ2mLsAkSHm7Z2Ooxi3OiqO+cXgrqgpnGHZe pZJHb3wHeOEfOntnJMriVh1RO2n5zUyjm5ydM+kEMfM5rbnv5JeuJb21FHVZOZNgRFWh r6RtTSY6sjmMTTLMorCF9rKSf6y5AFbT9Um8rI5xeRQS/6ljSX4ubgJX4bSChOd/jBO7 YnrA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:dkim-signature; bh=iNbjq4C34pR6QNWDK9+NrPFMsPQVY+YacZkcNLYf6FE=; b=q1Bq99mE+39aa7TwG2O9G4BFdv2Tqi/SKy1VatJlXjkuPNItMDBk2liGYlbQJeeBnw LiVrwh7x+IcKSqi74RTa/mhpEr9OVYdsJcW1Y7nkYvhPV4EPj/+n1acbzDLuygg50onZ +4AI3VsZCypKaBeWeKvn75SZwLE8bt3diFI+qbcSU6hzr4hVvaDCl+7nJvwOfajyoPX2 aE6+yi1oksFAcRTiGRQw44QWxxYprfJnmomzQGcDnwjQTexLNrG+xgT0Cp78bzoQA9RM K/BXgCWJFeIUyXdJ/ZRchqplVXvkbqFBkKtyvFOvpSET3NuFSLOTlIwVCeaIo059d3rj 3XBQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=ys1e1lHs; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n26si5130576otf.312.2019.12.13.04.58.31; Fri, 13 Dec 2019 04:58:43 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=ys1e1lHs; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727504AbfLMM4d (ORCPT + 99 others); Fri, 13 Dec 2019 07:56:33 -0500 Received: from lelv0143.ext.ti.com ([198.47.23.248]:41724 "EHLO lelv0143.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727443AbfLMM4X (ORCPT ); Fri, 13 Dec 2019 07:56:23 -0500 Received: from fllv0035.itg.ti.com ([10.64.41.0]) by lelv0143.ext.ti.com (8.15.2/8.15.2) with ESMTP id xBDCuMCp018534; Fri, 13 Dec 2019 06:56:22 -0600 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1576241782; bh=iNbjq4C34pR6QNWDK9+NrPFMsPQVY+YacZkcNLYf6FE=; h=From:To:CC:Subject:Date:In-Reply-To:References; b=ys1e1lHsWA+eHLVC79t34J7h8IfYtipG+cgrMr0dldi79xcjTnHPZYm+m76ixgzBs DgsxQUyxNssk/n9gqy6dWFbE/O3/hF22UqOFMFjlpP5mVwkOIRLP7p769FjlfZY09D lNgHu6NG+3A1yVY9RvD8A4ciP2AX0vhFZV06BImU= Received: from DLEE100.ent.ti.com (dlee100.ent.ti.com [157.170.170.30]) by fllv0035.itg.ti.com (8.15.2/8.15.2) with ESMTP id xBDCuMNK009092; Fri, 13 Dec 2019 06:56:22 -0600 Received: from DLEE107.ent.ti.com (157.170.170.37) by DLEE100.ent.ti.com (157.170.170.30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1847.3; Fri, 13 Dec 2019 06:56:22 -0600 Received: from fllv0040.itg.ti.com (10.64.41.20) by DLEE107.ent.ti.com (157.170.170.37) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1847.3 via Frontend Transport; Fri, 13 Dec 2019 06:56:22 -0600 Received: from sokoban.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by fllv0040.itg.ti.com (8.15.2/8.15.2) with ESMTP id xBDCtwVP127295; Fri, 13 Dec 2019 06:56:20 -0600 From: Tero Kristo To: , , CC: , , , Suman Anna , Tero Kristo Subject: [PATCHv3 10/15] remoteproc/omap: Check for undefined mailbox messages Date: Fri, 13 Dec 2019 14:55:32 +0200 Message-ID: <20191213125537.11509-11-t-kristo@ti.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20191213125537.11509-1-t-kristo@ti.com> References: <20191213125537.11509-1-t-kristo@ti.com> MIME-Version: 1.0 Content-Type: text/plain X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Suman Anna Add some checks in the mailbox callback function to limit any processing in the mailbox callback function to only certain currently valid messages, and drop all the remaining messages. A debug message is added to print any such invalid messages when the appropriate trace control is enabled. Co-developed-by: Subramaniam Chanderashekarapuram Signed-off-by: Subramaniam Chanderashekarapuram Signed-off-by: Suman Anna Signed-off-by: Tero Kristo Reviewed-by: Bjorn Andersson --- drivers/remoteproc/omap_remoteproc.c | 6 ++++++ drivers/remoteproc/omap_remoteproc.h | 7 +++++++ 2 files changed, 13 insertions(+) diff --git a/drivers/remoteproc/omap_remoteproc.c b/drivers/remoteproc/omap_remoteproc.c index 6cf7f0a9ba9a..841981c50d8d 100644 --- a/drivers/remoteproc/omap_remoteproc.c +++ b/drivers/remoteproc/omap_remoteproc.c @@ -126,6 +126,12 @@ static void omap_rproc_mbox_callback(struct mbox_client *client, void *data) dev_info(dev, "received echo reply from %s\n", name); break; default: + if (msg >= RP_MBOX_READY && msg < RP_MBOX_END_MSG) + return; + if (msg > oproc->rproc->max_notifyid) { + dev_dbg(dev, "dropping unknown message 0x%x", msg); + return; + } /* msg contains the index of the triggered vring */ if (rproc_vq_interrupt(oproc->rproc, msg) == IRQ_NONE) dev_dbg(dev, "no message was found in vqid %d\n", msg); diff --git a/drivers/remoteproc/omap_remoteproc.h b/drivers/remoteproc/omap_remoteproc.h index f6d2036d383d..72f656c93caa 100644 --- a/drivers/remoteproc/omap_remoteproc.h +++ b/drivers/remoteproc/omap_remoteproc.h @@ -56,6 +56,12 @@ * * @RP_MBOX_ABORT_REQUEST: a "please crash" request, used for testing the * recovery mechanism (to some extent). + * + * Introduce new message definitions if any here. + * + * @RP_MBOX_END_MSG: Indicates end of known/defined messages from remote core + * This should be the last definition. + * */ enum omap_rp_mbox_messages { RP_MBOX_READY = 0xFFFFFF00, @@ -64,6 +70,7 @@ enum omap_rp_mbox_messages { RP_MBOX_ECHO_REQUEST = 0xFFFFFF03, RP_MBOX_ECHO_REPLY = 0xFFFFFF04, RP_MBOX_ABORT_REQUEST = 0xFFFFFF05, + RP_MBOX_END_MSG = 0xFFFFFF06, }; #endif /* _OMAP_RPMSG_H */ -- 2.17.1 -- Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki