From patchwork Thu Feb 1 15:13:37 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jinjian Song X-Patchwork-Id: 13541211 X-Patchwork-Delegate: kuba@kernel.org Received: from AUS01-ME3-obe.outbound.protection.outlook.com (mail-me3aus01olkn2154.outbound.protection.outlook.com [40.92.63.154]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id DFC1A62141 for ; Thu, 1 Feb 2024 15:14:29 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.92.63.154 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706800471; cv=fail; b=ppCa0hOXmYh8qnBHXQ8XdJUogqPxIHQgaDKDIJqiGdujKO20I4oqhD3Hl2ozS3Nd3KS+6EhI5V3fGDNA2Ys5gAcgxkE6xS6XJHZRkto6rD8bsoNiEIIwPjM5dU0BcQ7FCq3kM1sOpdNlApVrUWaasqOJt+b0iX37Z0iiDPS+O9A= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706800471; c=relaxed/simple; bh=tSTVT5JifVBrYIYpdQDhEIto5sAGhU3PSPIfxLwlK4M=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=r4bLzQOx2TZxfwXz3DPwTrNxar0qu64LbdiA1fJPpQzPjYXrPTPMsO+IIApC5DoBnzS5hz1k7QujWc0atguwUN5oyPcY5aJwxyoQ1rFv+3gMs29XM0QS+zMEfZ0Z0cvWqE9pGmPmh39Heb39K7dFnydGVVTY5k0dplNDiwooGN4= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=hotmail.com; spf=pass smtp.mailfrom=hotmail.com; dkim=pass (2048-bit key) header.d=hotmail.com header.i=@hotmail.com header.b=sKJXDq10; arc=fail smtp.client-ip=40.92.63.154 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=hotmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=hotmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=hotmail.com header.i=@hotmail.com header.b="sKJXDq10" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=VAj+Us8XRYXBpYGbij1LwKy514D15iC2pB5Zn/dQtq6nvLyM6OOdbsK4AoF8IMHbEAf1Ik+TJONLWJq9DsltDuemzoQuqflHQx0JIRxouo4XlBHXNVn+GwrA0Idfgzig+LUg0ICEQBI70mmtIL2JDbbuDfve8WXofbSv4RBh3g0hV+b/6qkR60HESBPQ0SkzstP1bzaFqgjww5S2sTc8ZulO7QGgQ/FrGymXOy/fJkLfCUXIndCFwyurrtNG6ptITUJJz6xr8bbQSaYLNm1kNUzO6fFfYDd78iXpN4PonU0nDgDYbpukf7MT9VY5GXdnPDQLBS6kb7xRYIPqbUHsBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=xaYveMkzatic5z7fVTtAMe7sAZamFbpD5ScLU6zNXro=; b=ApVR3UJ+4wKQtKTkwyIZaqUQsAlb3zm316HDFHfaGik1YWyW5885beqD8WS/3+4KsvfubRf9rN/+6J/LNAsaNTiOzvGHU2FMoOqdmW1HNk2vt1bura6lSOoTcuh04OJyBC2KIiSQUd4KzlFsZtkbw7Tr5p7HAcWdrHkNXe3YOV1jxggwVMT9zJ5Stg5e/eYSeuTp+/jfTauTtV368xt0aqC4uLlM12/ADOtAHwpAby2O8ATRHz40huSgnx8w6LQ9l94PnSzdBRyc/ikedGh4sXStewLxbcv1sm4ssaPBPoQNcI10W7r2mP6+YgcDhjNWKHuj5DrYWjemlfLvcEHRAQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none; dmarc=none; dkim=none; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=hotmail.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=xaYveMkzatic5z7fVTtAMe7sAZamFbpD5ScLU6zNXro=; b=sKJXDq10vagg9XnaKq9Ze2hj+zGwQHljVQtX5fB/DPbRIoFy9agUkHix3I+En+YioJz5MtEEY/gZkVJni0JbJekeeAu41oRMkQlBrF9mFgTUvueJsd5JeU5OIrUDQFRhx7BI0D9gHmnBrkN+ZBCW/pGX5hIRVM6/ssxiw1+vmbg+QMW/sMwJ4MbwKrnXWV6RBIZtHn/OyYvrsZ5kxo7HqI60f3QszIDYc5i/HW/lK4wVCX1zsDaVMX0sKMfUWimv/WypAAhpkY61b9fYN08yUlKzm7Zw0MFZvneAjz5XGozlGw/ThdWvFnQEOAZcA81guVhWnIjTlXl8u8i1ZTRwgg== Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) by ME4P282MB1224.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:9a::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7249.26; Thu, 1 Feb 2024 15:14:21 +0000 Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::4b5:c5db:e39a:e48f]) by MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::4b5:c5db:e39a:e48f%4]) with mapi id 15.20.7249.025; Thu, 1 Feb 2024 15:14:21 +0000 From: Jinjian Song To: netdev@vger.kernel.org Cc: chandrashekar.devegowda@intel.com, chiranjeevi.rapolu@linux.intel.com, haijun.liu@mediatek.com, m.chetan.kumar@linux.intel.com, ricardo.martinez@linux.intel.com, loic.poulain@linaro.org, ryazanov.s.a@gmail.com, johannes@sipsolutions.net, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, linux-kernel@vger.kernel.com, vsankar@lenovo.com, letitia.tsai@hp.com, pin-hao.huang@hp.com, danielwinkler@google.com, nmarupaka@google.com, joey.zhao@fibocom.com, liuqf@fibocom.com, felix.yan@fibocom.com, angel.huang@fibocom.com, freddy.lin@fibocom.com, alan.zhang1@fibocom.com, zhangrc@fibocom.com, Jinjian Song Subject: [net-next v7 1/4] wwan: core: Add WWAN fastboot port type Date: Thu, 1 Feb 2024 23:13:37 +0800 Message-ID: X-Mailer: git-send-email 2.34.1 In-Reply-To: <20240201151340.4963-1-songjinjian@hotmail.com> References: <20240201151340.4963-1-songjinjian@hotmail.com> X-TMN: [/XwZLXV6YlwgrSkTbGI7T/Tf2APbo5iV] X-ClientProxiedBy: TY2PR04CA0004.apcprd04.prod.outlook.com (2603:1096:404:f6::16) To MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) X-Microsoft-Original-Message-ID: <20240201151340.4963-2-songjinjian@hotmail.com> Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: MEYP282MB2697:EE_|ME4P282MB1224:EE_ X-MS-Office365-Filtering-Correlation-Id: 82051ce1-93e2-455b-0585-08dc2338774f X-MS-Exchange-SLBlob-MailProps: dx7TrgQSB6freGFPHZ3GjGHLcCLCqTPftMoxoG8hQ4WW6PnidUL+inuVI/aZjcql/5PM9L1xiv5AbOrP2o+0dVRHSiurh50f0VftOY9VHPx8ahsuT6BPDLlMgfgt6JyDOo3hvylp4VeJ9pphROD93fd23SagKWWIQVgpGzg39KAA3iqtfc5Rs8qdM4voQWwhE7vSBjnlORCDKQCKdPh1BOcNHGEUk8J29NPP1ynEMOFK4fThMZyXSrhgSglGBuS22N1fvc53Jy1qvR+BSV1w3VBpPTai7SfNPhnYWdv/nt/Cask/dnuiGPjbgOQnSY9syCCeGvnhfb/1UBB2sRfFbtVj3SDSNpw/EiJi7ZWJvpIzhx9Om3M2gA0z5NshncI3n/VOGt4wLCK9ITEClmAWgtiK4C2h9DpqEVJNsbxKiS2ekjGztDIZUEw3WeKqb+EBgrQnGzO540I4Uzg715OFegGuO9fyZgFclKEzS2FWHC828Df4n9JsC/X8TbdDuiSa3z2QAAWMzBYqSiDxWKsuYYT4m0/Welr4dVJAlBJb1MbPhVG7gGvNlA3A0bZvgeAndcZfxThU+V/JwyClBnQ/ceBtPkM9cXk4pd9sWZp52rgZuzqBnPA7o6VzkwXfXoiufo/HmPU+Uz4prFU04oYnWA9iK0DFjtgHnqhYzQ2Y/zd0La8q/bPWNoktsT9ap5FT1wYotmoSDYQ1D/q7BxRuN+yRzTtEwDPeK4FZ1STrmQkWNjnqNZ6ocXifOlcFrwvAHC9PdUubANw= X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: ArvNYIL/+4IWhK8x9uWHFm31wOeMz13Tni3tMRlHLIHZ9cX/enm3H2+qiNzuO0k5hPqPWbAm4U8msIYcOt9aVUwKX0aewL02A5EnNz2KhVE4gG4MJrZmvaawx0mH1cPEZFDhXn6jPzP0fTDq5MnD+u1xhXjeMvpddnz6eeehoTFn68zXfNYg7kUFRXQJFHhJot98kSwUc5+owdExmXd/JiWLKf9iAxzCV2UPev5Jli+wDjhadLFPzIcXtL93y7eUL1smvfIvpIjZ/sheD+Q66+U3oxh8OHDMW9lKyx/i1ZbSnc2vU5SQ7DdWztzlaxfumztIJx/rNT7FSJ331n+h4RBopP3vh/mbcCeeuCzGTY+CZ8hzw8oLWqi/TDEC6YltH51f9aJk2Fv9ibmKHWVdY5FIgHORykO19vMtpmUf6SH+oCxGUZVUIi7C+/vg/9g9SEjqWGdTjKv1tD/nosefwa6/gLgjFdkNv/T+fmu6MdHFHPOrr4McvcfDdo4J9y1mq6mVmTM24gSyPqVRpusAPRJxolo/VE/EOriqbD9fnq3jBGYHq0WUh4SemdhRRdeO X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 4JHlZ7h9Ib1ETFmaZ8ZOtz58kz5JOjyr8EXDw9RbKN/veXFECFfcezWidg7qoKCJSBahE7AYgi20n1y4PR0rBaLR1rs9yTX4yxd/I6BOmuKn5XlkoYEEG5mPWt37/8HsqWgmeWYqTnyCcAFXPK5duhP2o6BXNLTFe67weybwI1B+MxUdJiE4Z4DTGdBBqLZ0trZ19B7jkS8n+raTcqhniFtxx1AvornTmtDDvKrU5rM4sqaZeYXRkXaqBtd1sEQJd2o71weeo1xFAzFPeS2Q2bqiIsAsQ7qeUPJ8qxGqVoJF09aVGpoWZRIboRz7I5qFQLpiC8UmyKkaV8sJA2uJy3BunRvLFS43k2BK3jz+nJo+fG0M6ZhIiTyS7ktBbJ0+bLPabf0ArAOOAlSEE3xvJjzj9dk0syDx3l3fdPEq/ThDwPsSHkxrD4jHEEV+4X3oRbkxAtAwmgIaLjvYNWVpkXJbDZiYrs21YZfbCmeW3eAjmpz1YETGvj3SDmpq7xZyuQiBB+AFUENVWR59sHZna9x4sUimVACr1WxJQ9+Jeqv37z4BFq6G38A4B/ChTRNCu1XGRUkArdB6uMcDo3IHR2la9ek2oIu6Ma/4IwVsp0iiYNlEIrFUeuTBznCvpzkKp0al2zxsoD8BPx/i9TqsXAsFI1R5SiqmaVt58zl/OMJeboM/g0vKZFdJ60aP8xnd+nv6Q3X25mYqJvL3erU9+yKQXJ1Duf3d3i2R1HU37C+AjyyTukxRXnEPD+9idW18XDgui6OWQMUcMfIZ2FBfReWpX5qlp1P1hOPLcfoMtldMFbLEAM509XAQM59mfGIOzXmLjX5/JK9fQ9cZn9HxzgepjyLQ7qDSlSogvYuCun2kvXl3lTq5/cP8gsqZBiKq6wlJLIHDPbVhZO7qP+8Pl5YtBgdskJXM8xrmY0TZsO5LpUtBmzKMwxhGGYHZ6a0Y3biXadJdib9D6+e/kJ+8L9H2YI/hf5rPycw3mD0KciVkjh8XeoUGp34x+Efpo+qSlP67iMf+woal3L7aOWDeypP1ENFizC2MBy/iSY1DYrS3gkqqJsDom/NUj1KWilJ+tD/wtYVErS3DLSSupwS9tUiM+CL9sptEYZmFtc7SSVpGbdkDjQlJD9jwWouG9JazuV2uN4RWhgCP4noZOoY3RfZvFiAOzS/0db0OU960ImMgS9ITkgdeYzUkxm9U13Ouhw/WA4zF1fWFWNg1wtc2YP5gfhlw89/V8N0p04NJFsg= X-OriginatorOrg: sct-15-20-4755-11-msonline-outlook-746f3.templateTenant X-MS-Exchange-CrossTenant-Network-Message-Id: 82051ce1-93e2-455b-0585-08dc2338774f X-MS-Exchange-CrossTenant-AuthSource: MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 01 Feb 2024 15:14:21.1912 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-Transport-CrossTenantHeadersStamped: ME4P282MB1224 X-Patchwork-Delegate: kuba@kernel.org From: Jinjian Song Add a new WWAN port that connects to the device fastboot protocol interface. Signed-off-by: Jinjian Song --- v2-v7: * no change --- drivers/net/wwan/wwan_core.c | 4 ++++ include/linux/wwan.h | 2 ++ 2 files changed, 6 insertions(+) diff --git a/drivers/net/wwan/wwan_core.c b/drivers/net/wwan/wwan_core.c index 72e01e550a16..2ed20b20e7fc 100644 --- a/drivers/net/wwan/wwan_core.c +++ b/drivers/net/wwan/wwan_core.c @@ -328,6 +328,10 @@ static const struct { .name = "XMMRPC", .devsuf = "xmmrpc", }, + [WWAN_PORT_FASTBOOT] = { + .name = "FASTBOOT", + .devsuf = "fastboot", + }, }; static ssize_t type_show(struct device *dev, struct device_attribute *attr, diff --git a/include/linux/wwan.h b/include/linux/wwan.h index 01fa15506286..170fdee6339c 100644 --- a/include/linux/wwan.h +++ b/include/linux/wwan.h @@ -16,6 +16,7 @@ * @WWAN_PORT_QCDM: Qcom Modem diagnostic interface * @WWAN_PORT_FIREHOSE: XML based command protocol * @WWAN_PORT_XMMRPC: Control protocol for Intel XMM modems + * @WWAN_PORT_FASTBOOT: Fastboot protocol control * * @WWAN_PORT_MAX: Highest supported port types * @WWAN_PORT_UNKNOWN: Special value to indicate an unknown port type @@ -28,6 +29,7 @@ enum wwan_port_type { WWAN_PORT_QCDM, WWAN_PORT_FIREHOSE, WWAN_PORT_XMMRPC, + WWAN_PORT_FASTBOOT, /* Add new port types above this line */ From patchwork Thu Feb 1 15:13:38 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jinjian Song X-Patchwork-Id: 13541212 X-Patchwork-Delegate: kuba@kernel.org Received: from AUS01-ME3-obe.outbound.protection.outlook.com (mail-me3aus01olkn2144.outbound.protection.outlook.com [40.92.63.144]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 466C24500F for ; Thu, 1 Feb 2024 15:14:39 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.92.63.144 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706800481; cv=fail; b=otIe3orNewXyIcAeX5p7U1m38gbfoTllxHDOppcbW9Z8LueqXs2OPUNRQSSE97xel1lxkD03wdqYdXXHx4Sdcvna+ja9GPcRKsT3JI6KbWcEca5qdGJTw+mtVeHqiN6Lj5fva/R3ZERJ/yoAR5IfAK+qQk+5XvgDq6/Wh8AqGk0= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706800481; c=relaxed/simple; bh=mVsNdlABjyQvB6grxQ7pWryCQ8gEtKU/7G22oNoRMQM=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=OhqRpAYQVMaT4D7NAHqp+rOLR4D/2a0jcU6VMnRR2kKfj7hqGF/6BWKLZK3rBMpyzd9rdGBn4592Znmj2jMpEx47i5UIQXIexiFLxWj68S19Yz25tiegZymGPFIYYhPYVix6jhTA8b/9F49PJjmC7Vae8PbNXyXkJOPPV+HhCi4= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=hotmail.com; spf=pass smtp.mailfrom=hotmail.com; dkim=pass (2048-bit key) header.d=hotmail.com header.i=@hotmail.com header.b=aTi+GdlZ; arc=fail smtp.client-ip=40.92.63.144 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=hotmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=hotmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=hotmail.com header.i=@hotmail.com header.b="aTi+GdlZ" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=XmA5YIo5+8W0WFFZH2DcZQHiWxES4xuniQDhRhdpJMltQIKTDE93W9OuNX2IwR7IyY0O2hDlh4nlvc5Tos6ErD08y6HRwjvtt5H7WZ1+fogegbq83KnwfZiIscwwWiK7i6lc6dwP4uc7h2WeOJOcLNV1AnyXCjxHD9F6Dam4D4yIyF2aShjBBMZj8Bcsfsdxu9z030QAEC6VEBNsvUOlPSWlrMhMhdcRvYpquSTQYSMmBy28/OCRpiliVBOPIkOemAZWJy0snTTDvDzYI7NLdon1J1WmlHVKfNvkhJwTsbBRdE97BRZRHLsa/B8UFmKvcpBztRNqsKpDZKlZQPkMnw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=Dn0lU6B9OopGvLMxAoCB3hpfiC/suxxjDxovM4lj5X0=; b=NjiL3ERpXsLxIXMcD9Nu9gvccWiAW/z2HJUVxCYxAyYEJc9KRtfzA7sMINbSCGhbIoclmIRwFJWv9VapLXyP+vvXRYVGNyuSCep9xIXtGQfTrk62rKApvUBnn0pw9tQ+daeCybwz1jqZa5sPoDZyKD1KZXCB6Me97q7pgi1AnSvMu7brdNJk9yiK+QhcHLLMY/7pquKiZHVKq2GSgtxYwxpdBSnQUzt637gVrS93Aw1UL1QAge07JDdw+55yOxLRAFR4WAFTXkvd8GvYQsnQsKv1YDyKMVtJ4oWxt74/E1C/NuHjwq87CewszeJHBrbS8GtPzbaRXJLW1u/1hN15lQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none; dmarc=none; dkim=none; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=hotmail.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Dn0lU6B9OopGvLMxAoCB3hpfiC/suxxjDxovM4lj5X0=; b=aTi+GdlZk08APfXclEzB68yO/pibHplNeb5LB9MmR3igUcXDgptjiPvdPhcAUvIXK39TxHVxobqAx0IN8+Ek5n65xHAtFIzcswem6TOaEiUfYBKfNaVtU8NIT9tvDC9Xkpu/8sqHPE7SLjfER/tEbO744FzezJ+3vYL77NnGDr53WIZK4tBFHByTUqHqn7dn2+ioFIaX7BNqxuF3DcgQYGogymPp/Qe5GGWICuKXHHuS19YutkbhEjTZove4RqRiv+cBiXoaZZp36KYbtxS28RwlV3WYMSuU8uFjX8zavuQysrpPRgzagcNLz+yZGyfZ1y2VEvX9CJbq4pwY0NIscA== Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) by ME4P282MB1224.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:9a::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7249.26; Thu, 1 Feb 2024 15:14:31 +0000 Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::4b5:c5db:e39a:e48f]) by MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::4b5:c5db:e39a:e48f%4]) with mapi id 15.20.7249.025; Thu, 1 Feb 2024 15:14:31 +0000 From: Jinjian Song To: netdev@vger.kernel.org Cc: chandrashekar.devegowda@intel.com, chiranjeevi.rapolu@linux.intel.com, haijun.liu@mediatek.com, m.chetan.kumar@linux.intel.com, ricardo.martinez@linux.intel.com, loic.poulain@linaro.org, ryazanov.s.a@gmail.com, johannes@sipsolutions.net, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, linux-kernel@vger.kernel.com, vsankar@lenovo.com, letitia.tsai@hp.com, pin-hao.huang@hp.com, danielwinkler@google.com, nmarupaka@google.com, joey.zhao@fibocom.com, liuqf@fibocom.com, felix.yan@fibocom.com, angel.huang@fibocom.com, freddy.lin@fibocom.com, alan.zhang1@fibocom.com, zhangrc@fibocom.com, Jinjian Song Subject: [net-next v7 2/4] net: wwan: t7xx: Add sysfs attribute for device state machine Date: Thu, 1 Feb 2024 23:13:38 +0800 Message-ID: X-Mailer: git-send-email 2.34.1 In-Reply-To: <20240201151340.4963-1-songjinjian@hotmail.com> References: <20240201151340.4963-1-songjinjian@hotmail.com> X-TMN: [OAzt537dBn1AlU6NNjhdz7QDs+PeFIbX] X-ClientProxiedBy: TY2PR04CA0004.apcprd04.prod.outlook.com (2603:1096:404:f6::16) To MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) X-Microsoft-Original-Message-ID: <20240201151340.4963-3-songjinjian@hotmail.com> Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: MEYP282MB2697:EE_|ME4P282MB1224:EE_ X-MS-Office365-Filtering-Correlation-Id: beed07e5-e376-4928-8667-08dc23387d1e X-MS-Exchange-SLBlob-MailProps: dx7TrgQSB6freGFPHZ3GjGHLcCLCqTPfz+d9nc/HNS3hqppNUbPO68k1YefrXhwbg9+5u9ZwYrrFf8WcQv6ismjNUz9I3mZXqyt8F/8bjljeYw9BCBc2/O3lqOoBFTi25pVIXg9euNFEV+TC1N9OsQsOSTBjuC0AJhEPuqghMtQ3FZAgCluxiS6HBkc2XR8LOnbC3Dn0S9r+sqPhkEhONZA8S0wb8eR6u7EUGb5A/h0eKkTs1he8t+DUJGvRvy6MoPw08zbXfNtqTweuPIvpEgmI6s97+TMZl5X9U0eVLuix0PL+iEjtu7RDxMQx+PvcH2L0mibYMzlQ4u9zPdX+9azEKOwQo82JGjgh9H5n/TqyTbtj1nPF9UGZgCQC/rKuvoL8NqjSTTDJXRKtLG7k5Lgo+TXuDPV4MpKs3UEWvyiYjKPahqP5V2uLQzuPDIO5iYuUaGJrZlbgACEbVRRczad+XzX4V22qe8gXXsqwdU1NV6MhCNK+ob2YDBPjA/an1KZQmluYnAXokuPPzmCyguiofNf6hK38p3A0J11+h6yLG0cNdNmQdLqLftgSZRRDZTYwM0WEQ4RxjufK4HS1GI9HQ8ZMSqQ4E3/MbKJ4qEVF98tEhmuv9NDB3Xrs29rz7hAXwmVg00I9oGYdGBvOiecXa5IdoOV98Camci7c0mW+4/oKgEHz4dzMbTqwqRhuJ0eWQxNmZQQAtwPfPT2twz0672T363wtgQv0eiTaB164w4ciRZND22z/i2UemdQPK5zQIc9FMM0= X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 4+jR6vFVX4k35uQLlA3+GNQmSSjSiq2JrOu/Y0B4IH6ZwRQ1WmqG11VznBjhT4mQNBaVJmeIAdZtuJ2lae7nulYCAEdUTotngqSDCVSgRUvGqiOWkHRYRvjlsKeO3B2uuoptxMS1ork4XiOCczjJm4buhXfUdhsigQ9F5puzXo5N9Pw2jH3PWT7QUgxnhDk8rbbodhX+W23i86em2I826OQLJlPuV9CQxywMIM3/m8EKlNoY2boBwSjGmDW62E0q+GQ1690qfg1t67ayDm8EcK7XA0m7u7H5CTyz5rL2gEASd/a8dSx6AZ6V1GodqCVTarmhWSESr+ijaHesyVP8IlszdildwU0jWI/0oNWY+dNxiKXDpR4MUJP4bFy1bCLwcj2349C2NXn1vpFbss7eCaptOj+ZHeS/OUepBUu+4UVjbHaNa0v7MmFYWoTPqSALjcgBecPFxDs08SaUn92vyvV+uD8H+lXSxgmbCPLcVdz3P5SrsiDR+GAAWCKB0Gd4154oPJ4BZIUsw2gkLmCa3wuliBEnvtlKY1CRmMevCTYm/Iw1MCkMCyrZvQxGpvvg X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: qEqXWv/QYXI/PhoC+zxmeGIEWF6gfnt/fyzljBeoGxoeazWq2m90i/BeRkRlTUhcRAt4/JGk+fuU/XBk4mGr7aRXjBHSPlKhVTrMg1WFhlKoe9xg197kUi7RE/mpyctB+zvJ90QomaehwVNzYMLKad1MsTj565D6M856HzG3DgpIodwD1Tq83mC41Cn8DmSW/9SgGfSA49MgNwOPnJrqXm+iaC5PxYe5EVZrszlYQfO4hMgmiCUaAmF7g5PJM8xWi04gwoNDDyeGZdAmp+LOIdLkvVOx/5QpAhi22p7NHTIi6q4lKHwA2KqhcyN1wQOoheaobV33zx6WHpfCTLmZsBrUk11Fm1HvkYkPA4IZvFqlIKd2KD6kvYdOI/6mYocONhLGxVqBMjM8lXlWVceg2z7iCv61o5Qnl79B5Kw4ZpuvvLqR/iw2HK9SB6TPtUjwKp1S5GNFjVU8B0D1BKgbF4rPlgaInDUR+sAW63+wsWsWPH+6HLPrWzuoKiYexcu5Ny00SQQUrTARQT1d3eaBe1Owf10E4DconrfBIZUEZPEZHKathIEf2DzvC/rzY20t9YyM6++zIKE3tX2s3jJYpS/1S7cVQ+X2id9trnYAjiPmtX8AJcefcm6s6rXfpP/e1NHGsxGbVrOF9qE8WhgqNuZjOTWJuwc8z6le3fT3zQYy8B03lpBhAcSbd3mZm4eerU3GAMFk67mUN4dz591cp4E4QQBeX1TD6ifUypCBo6r2GVl7AOd/JxlrazWzn3NQwElQGxzMAVAJcnyZwuSn4D3SfUDlNjgKiIFMoT/n+wnJnoRXxZbeAyHIHOgfpkTv6+fG3G5n4qXucj71kKZuaDug09SP+XSyuKhwmGBRYvUTgqlmM1ZEzWLvt0tcNqssuPLMk3Alk13wgLKXqlpxVLebqQbjYld+CBQJVEBNNopgfSL9nclqUhW1dx3lZjFiacb2hnpQMpCiRgAwR7SmhxMfyYy6QMSflfmONHy3uSSdMxO0PrfrkyvZPdksQ6KVCzZCSrZFtqKMQlQY9ANBCuWU9GvswCulXJGlFJExbaAlzjES7jYOqxJm+jKRStInLZhUQ2Y1cp0KCxoR3bEVoVFKv78n5KVRUvrNMNRv0z+vldNC2NXWEhvT/Hd4EfW+m2A92ujVPJk4uKN+C6LD4YnReIvg+PU0d5XeuIFGLnloc8KqGzpExRrzgjtQpfesMYVK3SlkZKx8ZKp+y/3kSL6EJsQDoREZ57AX1hY4Q4I= X-OriginatorOrg: sct-15-20-4755-11-msonline-outlook-746f3.templateTenant X-MS-Exchange-CrossTenant-Network-Message-Id: beed07e5-e376-4928-8667-08dc23387d1e X-MS-Exchange-CrossTenant-AuthSource: MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 01 Feb 2024 15:14:30.9238 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-Transport-CrossTenantHeadersStamped: ME4P282MB1224 X-Patchwork-Delegate: kuba@kernel.org From: Jinjian Song Add support for userspace to get/set the device mode, device's state machine changes between (UNKNOWN/READY/RESET/FASTBOOT_DL_MODE/FASTBOOT_DUMP_MODE). Get the device state mode: - 'cat /sys/bus/pci/devices/${bdf}/t7xx_mode' Set the device state mode: - reset(cold reset): 'echo RESET > /sys/bus/pci/devices/${bdf}/t7xx_mode' - fastboot: 'echo FASTBOOT_DL_SWITCHING > /sys/bus/pci/devices/${bdf}/t7xx_mode' Reload driver to get the new device state after setting operation. Signed-off-by: Jinjian Song --- v7: * add sysfs description to commit info * update t7xx_dev->mode after reset by sysfs t7xx_mode v6: * change code style in t7xx_mode_store() v5: * add cold reset support via sysfs t7xx_mode v4: * narrow down the set of accepted values in t7xx_mode_store() * change mode type atomic to u32 with READ_ONCE()/WRITE_ONCE() * delete 'T7XX_MODEM' prefix and using sysfs_emit in t7xx_mode_show() * add description of sysfs t7xx_mode in document t7xx.rst v2: * optimizing using goto label in t7xx_pci_probe --- .../networking/device_drivers/wwan/t7xx.rst | 28 ++++++ drivers/net/wwan/t7xx/t7xx_modem_ops.c | 6 ++ drivers/net/wwan/t7xx/t7xx_modem_ops.h | 1 + drivers/net/wwan/t7xx/t7xx_pci.c | 98 ++++++++++++++++++- drivers/net/wwan/t7xx/t7xx_pci.h | 14 ++- drivers/net/wwan/t7xx/t7xx_state_monitor.c | 1 + 6 files changed, 143 insertions(+), 5 deletions(-) diff --git a/Documentation/networking/device_drivers/wwan/t7xx.rst b/Documentation/networking/device_drivers/wwan/t7xx.rst index dd5b731957ca..d13624a52d8b 100644 --- a/Documentation/networking/device_drivers/wwan/t7xx.rst +++ b/Documentation/networking/device_drivers/wwan/t7xx.rst @@ -39,6 +39,34 @@ command and receive response: - open the AT control channel using a UART tool or a special user tool +Sysfs +===== +The driver provides sysfs interfaces to userspace. + +t7xx_mode +--------- +The sysfs interface provides userspace with access to the device mode, this interface +supports read and write operations. + +Device mode: + +- ``UNKNOW`` represents that device in unknown status +- ``READY`` represents that device in ready status +- ``RESET`` represents that device in reset status +- ``FASTBOOT_DL_SWITCHING`` represents that device in fastboot switching status +- ``FASTBOOT_DL_MODE`` represents that device in fastboot download status +- ``FASTBOOT_DL_DUMP_MODE`` represents that device in fastboot dump status + +Read from userspace to get the current device mode. + +:: + $ cat /sys/bus/pci/devices/${bdf}/t7xx_mode + +Write from userspace to set the device mode. + +:: + $ echo FASTBOOT_DL_SWITCHING > /sys/bus/pci/devices/${bdf}/t7xx_mode + Management application development ================================== The driver and userspace interfaces are described below. The MBIM protocol is diff --git a/drivers/net/wwan/t7xx/t7xx_modem_ops.c b/drivers/net/wwan/t7xx/t7xx_modem_ops.c index 24e7d491468e..ca262d2961ed 100644 --- a/drivers/net/wwan/t7xx/t7xx_modem_ops.c +++ b/drivers/net/wwan/t7xx/t7xx_modem_ops.c @@ -177,6 +177,11 @@ int t7xx_acpi_fldr_func(struct t7xx_pci_dev *t7xx_dev) return t7xx_acpi_reset(t7xx_dev, "_RST"); } +int t7xx_acpi_pldr_func(struct t7xx_pci_dev *t7xx_dev) +{ + return t7xx_acpi_reset(t7xx_dev, "MRST._RST"); +} + static void t7xx_reset_device_via_pmic(struct t7xx_pci_dev *t7xx_dev) { u32 val; @@ -192,6 +197,7 @@ static irqreturn_t t7xx_rgu_isr_thread(int irq, void *data) { struct t7xx_pci_dev *t7xx_dev = data; + t7xx_mode_update(t7xx_dev, T7XX_RESET); msleep(RGU_RESET_DELAY_MS); t7xx_reset_device_via_pmic(t7xx_dev); return IRQ_HANDLED; diff --git a/drivers/net/wwan/t7xx/t7xx_modem_ops.h b/drivers/net/wwan/t7xx/t7xx_modem_ops.h index abe633cf7adc..b39e945a92e0 100644 --- a/drivers/net/wwan/t7xx/t7xx_modem_ops.h +++ b/drivers/net/wwan/t7xx/t7xx_modem_ops.h @@ -85,6 +85,7 @@ int t7xx_md_init(struct t7xx_pci_dev *t7xx_dev); void t7xx_md_exit(struct t7xx_pci_dev *t7xx_dev); void t7xx_clear_rgu_irq(struct t7xx_pci_dev *t7xx_dev); int t7xx_acpi_fldr_func(struct t7xx_pci_dev *t7xx_dev); +int t7xx_acpi_pldr_func(struct t7xx_pci_dev *t7xx_dev); int t7xx_pci_mhccif_isr(struct t7xx_pci_dev *t7xx_dev); #endif /* __T7XX_MODEM_OPS_H__ */ diff --git a/drivers/net/wwan/t7xx/t7xx_pci.c b/drivers/net/wwan/t7xx/t7xx_pci.c index 91256e005b84..1a10afd948c7 100644 --- a/drivers/net/wwan/t7xx/t7xx_pci.c +++ b/drivers/net/wwan/t7xx/t7xx_pci.c @@ -52,6 +52,81 @@ #define PM_RESOURCE_POLL_TIMEOUT_US 10000 #define PM_RESOURCE_POLL_STEP_US 100 +static const char * const mode_names[] = { + [T7XX_UNKNOWN] = "UNKNOWN", + [T7XX_READY] = "READY", + [T7XX_RESET] = "RESET", + [T7XX_FASTBOOT_DL_SWITCHING] = "FASTBOOT_DL_SWITCHING", + [T7XX_FASTBOOT_DL_MODE] = "FASTBOOT_DL_MODE", + [T7XX_FASTBOOT_DUMP_MODE] = "FASTBOOT_DUMP_MODE", +}; + +static_assert(ARRAY_SIZE(mode_names) == T7XX_MODE_LAST); + +static ssize_t t7xx_mode_store(struct device *dev, + struct device_attribute *attr, + const char *buf, size_t count) +{ + struct t7xx_pci_dev *t7xx_dev; + struct pci_dev *pdev; + int index = 0; + + pdev = to_pci_dev(dev); + t7xx_dev = pci_get_drvdata(pdev); + if (!t7xx_dev) + return -ENODEV; + + index = sysfs_match_string(mode_names, buf); + if (index == T7XX_FASTBOOT_DL_SWITCHING) { + WRITE_ONCE(t7xx_dev->mode, T7XX_FASTBOOT_DL_SWITCHING); + } else if (index == T7XX_RESET) { + WRITE_ONCE(t7xx_dev->mode, T7XX_RESET); + t7xx_acpi_pldr_func(t7xx_dev); + } + + return count; +}; + +static ssize_t t7xx_mode_show(struct device *dev, + struct device_attribute *attr, + char *buf) +{ + enum t7xx_mode mode = T7XX_UNKNOWN; + struct t7xx_pci_dev *t7xx_dev; + struct pci_dev *pdev; + + pdev = to_pci_dev(dev); + t7xx_dev = pci_get_drvdata(pdev); + if (!t7xx_dev) + return -ENODEV; + + mode = READ_ONCE(t7xx_dev->mode); + if (mode < T7XX_MODE_LAST) + return sysfs_emit(buf, "%s\n", mode_names[mode]); + + return sysfs_emit(buf, "%s\n", mode_names[T7XX_UNKNOWN]); +} + +static DEVICE_ATTR_RW(t7xx_mode); + +static struct attribute *t7xx_mode_attr[] = { + &dev_attr_t7xx_mode.attr, + NULL +}; + +static const struct attribute_group t7xx_mode_attribute_group = { + .attrs = t7xx_mode_attr, +}; + +void t7xx_mode_update(struct t7xx_pci_dev *t7xx_dev, enum t7xx_mode mode) +{ + if (!t7xx_dev) + return; + + WRITE_ONCE(t7xx_dev->mode, mode); + sysfs_notify(&t7xx_dev->pdev->dev.kobj, NULL, "t7xx_mode"); +} + enum t7xx_pm_state { MTK_PM_EXCEPTION, MTK_PM_INIT, /* Device initialized, but handshake not completed */ @@ -729,16 +804,28 @@ static int t7xx_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id) t7xx_pcie_mac_interrupts_dis(t7xx_dev); + ret = sysfs_create_group(&t7xx_dev->pdev->dev.kobj, + &t7xx_mode_attribute_group); + if (ret) + goto err_md_exit; + ret = t7xx_interrupt_init(t7xx_dev); - if (ret) { - t7xx_md_exit(t7xx_dev); - return ret; - } + if (ret) + goto err_remove_group; + t7xx_pcie_mac_set_int(t7xx_dev, MHCCIF_INT); t7xx_pcie_mac_interrupts_en(t7xx_dev); return 0; + +err_remove_group: + sysfs_remove_group(&t7xx_dev->pdev->dev.kobj, + &t7xx_mode_attribute_group); + +err_md_exit: + t7xx_md_exit(t7xx_dev); + return ret; } static void t7xx_pci_remove(struct pci_dev *pdev) @@ -747,6 +834,9 @@ static void t7xx_pci_remove(struct pci_dev *pdev) int i; t7xx_dev = pci_get_drvdata(pdev); + + sysfs_remove_group(&t7xx_dev->pdev->dev.kobj, + &t7xx_mode_attribute_group); t7xx_md_exit(t7xx_dev); for (i = 0; i < EXT_INT_NUM; i++) { diff --git a/drivers/net/wwan/t7xx/t7xx_pci.h b/drivers/net/wwan/t7xx/t7xx_pci.h index f08f1ab74469..0abba7e6f8aa 100644 --- a/drivers/net/wwan/t7xx/t7xx_pci.h +++ b/drivers/net/wwan/t7xx/t7xx_pci.h @@ -43,6 +43,16 @@ struct t7xx_addr_base { typedef irqreturn_t (*t7xx_intr_callback)(int irq, void *param); +enum t7xx_mode { + T7XX_UNKNOWN, + T7XX_READY, + T7XX_RESET, + T7XX_FASTBOOT_DL_SWITCHING, + T7XX_FASTBOOT_DL_MODE, + T7XX_FASTBOOT_DUMP_MODE, + T7XX_MODE_LAST, /* must always be last */ +}; + /* struct t7xx_pci_dev - MTK device context structure * @intr_handler: array of handler function for request_threaded_irq * @intr_thread: array of thread_fn for request_threaded_irq @@ -59,6 +69,7 @@ typedef irqreturn_t (*t7xx_intr_callback)(int irq, void *param); * @md_pm_lock: protects PCIe sleep lock * @sleep_disable_count: PCIe L1.2 lock counter * @sleep_lock_acquire: indicates that sleep has been disabled + * @mode: indicates the device mode */ struct t7xx_pci_dev { t7xx_intr_callback intr_handler[EXT_INT_NUM]; @@ -82,6 +93,7 @@ struct t7xx_pci_dev { #ifdef CONFIG_WWAN_DEBUGFS struct dentry *debugfs_dir; #endif + u32 mode; }; enum t7xx_pm_id { @@ -120,5 +132,5 @@ int t7xx_pci_pm_entity_register(struct t7xx_pci_dev *t7xx_dev, struct md_pm_enti int t7xx_pci_pm_entity_unregister(struct t7xx_pci_dev *t7xx_dev, struct md_pm_entity *pm_entity); void t7xx_pci_pm_init_late(struct t7xx_pci_dev *t7xx_dev); void t7xx_pci_pm_exp_detected(struct t7xx_pci_dev *t7xx_dev); - +void t7xx_mode_update(struct t7xx_pci_dev *t7xx_dev, enum t7xx_mode mode); #endif /* __T7XX_PCI_H__ */ diff --git a/drivers/net/wwan/t7xx/t7xx_state_monitor.c b/drivers/net/wwan/t7xx/t7xx_state_monitor.c index 0bc97430211b..c5d46f45fa62 100644 --- a/drivers/net/wwan/t7xx/t7xx_state_monitor.c +++ b/drivers/net/wwan/t7xx/t7xx_state_monitor.c @@ -272,6 +272,7 @@ static void fsm_routine_ready(struct t7xx_fsm_ctl *ctl) ctl->curr_state = FSM_STATE_READY; t7xx_fsm_broadcast_ready_state(ctl); + t7xx_mode_update(md->t7xx_dev, T7XX_READY); t7xx_md_event_notify(md, FSM_READY); } From patchwork Thu Feb 1 15:13:39 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jinjian Song X-Patchwork-Id: 13541213 X-Patchwork-Delegate: kuba@kernel.org Received: from AUS01-ME3-obe.outbound.protection.outlook.com (mail-me3aus01olkn2183.outbound.protection.outlook.com [40.92.63.183]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id A7B6B62153 for ; Thu, 1 Feb 2024 15:14:59 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.92.63.183 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706800502; cv=fail; b=obuyGTraz/KOcAfi5axPUt/lUYLpKhi9kyOcA40stIP1j6BfwbzKs9JrnfbMgxLsMofcBIGv69/DlVyDWJH2M9RrF9s5WeRY8lAZ52wHjmUIwBImq+idAlQGjqVnt7zE7/7FYfOpAfvZN1bPpt4fQr32eXPVcKV6m63kqzNGjh4= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706800502; c=relaxed/simple; bh=szZvuAb0HfB8tABgeWUdxPJSwHszHQKCCRKFqoglSvI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=ppVwVI4u9o3TRVtDnjXlfyDhtVw4vALGn+SPWw74KmAvqsQyq09UdKdV65zSoJ+zIhfHdvIpUUELX8Y4nbhyYfWA/xSYWb5BY1PU9PWwF1dc/TbfoxhffbvPhbDu3dJoRcjKNEXGaRN2yY8pfWCoH98xTpeX9mQYv86rq/qd9QE= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=hotmail.com; spf=pass smtp.mailfrom=hotmail.com; dkim=pass (2048-bit key) header.d=hotmail.com header.i=@hotmail.com header.b=JQWx3uOx; arc=fail smtp.client-ip=40.92.63.183 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=hotmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=hotmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=hotmail.com header.i=@hotmail.com header.b="JQWx3uOx" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=kR3hU7UwB2Fzw+wr22CkDCBG83PsacVUZ4P/c1SfAF2+iNm6E+/YXOsomQR+F8L/M+L7OAuT+SdOohcsapSe0/w8Dokb7c7zQExZPKSzZTi2wf+9MgaUM9+H9k2ta0+b5Cfsyc//eU79dND3UCXSALYYRdPfeBBFa3PXZ9d2ntXZQLJOvsuE3ipDmIa4hxyefjHJ53W37dJuoaXtjGr20nTQjZeW4YgvVxSGipEquD0BDt6pwZaPNd48uvk+UNlpcNbd2OnROwRsIeJY4TN+LgocpxN5tX5UQHJkUwk6cGdotJj50ndYdoemh28lvqaoEFQQTCHoXay4maRTds18rw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=4vUWTCShSXPGbG92DcR+JdH2ye8eLQPd4n9EeDbUJmw=; b=h4tqAmORbYU2TlW0Zn35x8V9CzpkTYzmvBWhNpeqiNZeoQwWGmctyl4MfCem/KiL1W//SClUFrLhqa1JgMQys0kcncPThd6q4Epnrpb+nxipe5a0eE0rXBbGi520ihuLiQ3XkPs2vwfR5gkd7Ypp9+PvewV/r+AHMC+DckyQey5Yk3ZAZS/aE3iH9bx9J2KHfshAJ11fCFEeW1Eoxx97fjL8qS2u7UVbErsG2ykiOrjAVCVkeg/Y6CUTBTWXJ1vBsw79zzhpjdriv9QLFuev1a8KojZ99arTiYvULsGZg8Yk2V2aAI4utElYziBlEaB0s7AZDzBiDjHe2FABfl2+bA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none; dmarc=none; dkim=none; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=hotmail.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=4vUWTCShSXPGbG92DcR+JdH2ye8eLQPd4n9EeDbUJmw=; b=JQWx3uOxanRH/vTgr6eyfMkcXw820g6k4Q8fUdmA4M+U3vkXpcPhY/WF8T2uzsGW4Ks7cHqzsPBTq9v6RQMyi12rWi7b6n/DVRG2T46xakLVR1Cg6dZLVVvFa3o6hWfuyIBMYKd0kzNeKWno1YiGP+sFgttd5QTtQwnt1l3LmRcOyTOI+beghfrBzzakQk4Nvt3eGbm9NfZqyVldvQspSrGK/4Ia5+nJL7hRpSU2xOysNo7UqlkcNt7AB0HJrBysK+HgkIGP0LuwuSNd+m6sktwrB6guqP+QYIsvcWP7B/bicDGjF/E1XXanJE/2vSHHwnEryTH22E6g0WqAiuTIsg== Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) by ME4P282MB1224.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:9a::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7249.26; Thu, 1 Feb 2024 15:14:41 +0000 Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::4b5:c5db:e39a:e48f]) by MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::4b5:c5db:e39a:e48f%4]) with mapi id 15.20.7249.025; Thu, 1 Feb 2024 15:14:41 +0000 From: Jinjian Song To: netdev@vger.kernel.org Cc: chandrashekar.devegowda@intel.com, chiranjeevi.rapolu@linux.intel.com, haijun.liu@mediatek.com, m.chetan.kumar@linux.intel.com, ricardo.martinez@linux.intel.com, loic.poulain@linaro.org, ryazanov.s.a@gmail.com, johannes@sipsolutions.net, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, linux-kernel@vger.kernel.com, vsankar@lenovo.com, letitia.tsai@hp.com, pin-hao.huang@hp.com, danielwinkler@google.com, nmarupaka@google.com, joey.zhao@fibocom.com, liuqf@fibocom.com, felix.yan@fibocom.com, angel.huang@fibocom.com, freddy.lin@fibocom.com, alan.zhang1@fibocom.com, zhangrc@fibocom.com, Jinjian Song Subject: [net-next v7 3/4] net: wwan: t7xx: Infrastructure for early port configuration Date: Thu, 1 Feb 2024 23:13:39 +0800 Message-ID: X-Mailer: git-send-email 2.34.1 In-Reply-To: <20240201151340.4963-1-songjinjian@hotmail.com> References: <20240201151340.4963-1-songjinjian@hotmail.com> X-TMN: [YqgnkqT1px4OiQAcQ/ChrBL7YoGH7SU5] X-ClientProxiedBy: TY2PR04CA0004.apcprd04.prod.outlook.com (2603:1096:404:f6::16) To MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) X-Microsoft-Original-Message-ID: <20240201151340.4963-4-songjinjian@hotmail.com> Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: MEYP282MB2697:EE_|ME4P282MB1224:EE_ X-MS-Office365-Filtering-Correlation-Id: e43c7130-83f5-42f8-8e31-08dc2338834e X-MS-Exchange-SLBlob-MailProps: 7J/vb0KDx3hb4GTTlIadAoOVXL722f/Lsqr7UCTumKGUvE0Eve5/6SFvbsHA6Z4Fu89eP0liOrhtHYQAFEFw4nlEjkd0qCNEkR7I2t9c++KUFqkBAdBbm+lPr3lxVNqRz0zgDT9RP9zOSCYbZBEhEJ7hx8LguKJ6iEomYmckH0IZCIYoO3SgZn/0jCKPQpMzqbEk1ktqTkwJBbRxzIMynyuoLQH2wvJnNBRgsHCH0z3IipQAeP1Z39ei2+ppmRPa4zVduookSLvl7uCGrOHdfZ6NAX83Hl2ImdmrQuQ83aUFELImar+6mEiWrYHwUa5Dui8EMUmcfMBbvWzsbPTmFEJBiaWcecalmtjpmWIaNgsQV+kIISK6NLXzId/+bkk53Hv/jWvAM8J40QjQQFR2r/lTquYIRRhEWlKsofogONLUkHiD1ZIp7JlBG263QPThij0OXtIJoUE/wZEdcTrpbRWAomgOD6B+Jdyk/jxp0FhiGDTCb/GaLKyOK6P3klPAqN6ESEgN2LKamcoYLuTQcj2UrANc5YiNRjb275FwuEu3zYM75Y/OqHEMut2FevIewrxyYVO6lAxEzl82VfKuepNjERks3ecxEJM5VmzW0jxac1tHmhe44yNdcQmI/5R9qPH+nI3A2nLp+PnRMAEsnn/RDDSDmuipnxY3NBPMGj0ib4PLs0Ogpv1OTRp08GzBfFCcoYLMd8Yis2f1EDeMAM8CU/W/b0XhO3dNkhWGKDSXcA9LI1WfuzQ61Smm3Qqn6QC6gVrAIZRJkxKtaF/Htw66aov0gRRRydi4rCC21Hw= X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: xpcJ9z1X8UH/pSI8PmrzSkvirwUBboQhRmsLE6tRAJ+h5iVHsWu/rOzs2v7zwUzKre63czcvU+Qd1DS4h5SiBG48XDzbCczLxysfHxDkzEjNFqutAkXLLdfjmVnVqrWYWvvpZjLH3GapAbTRd7gBPQiNGn/ICRYPtSwSaH2lROGrYFwyh0rxzsiYDlHMAUgoo2RyBkE7l0tTUXJpMOxrX2F32HQHfWo9dP0Az0FvABLCmVCUMlrXeoUT9IAegXP1vyZdWE6hGPlUStnO6LaixYt3LlOWZRNNr9FbfqQHmmQnTRp8UviAABeDdrXJ8q5/R49rI1tZIjqLsHw3Pmd1cYbIg/bGG3aaLxi6EZhSqJoRlaiqGwsMDB2YS0vx6WyxMtMFJ5tkKoGiCyXmLZhvE2e8XT+u5wsr0fEycJVTB4c9kLx/Gf1rzFaoAPc55DTsX1XCPt5pwKlLpXA3unk9yDQRMrWUeCBwvjaRWg44VQD8hTxg3c7OXSVgp8v3ZAMzE9QW13VJcEb+SiCnwHW8BVYh2WJ3KAFbdifANRk34Y1tq2RbnpUyd/PgvGGfSwiZGLCLJjli2phLzUPHgM9cP/DIzb2n1cRLOt2dtfyP6bU= X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: HTCEblhdyjk12w5vcT3LQZCXYhzah+/ySPE5R238jhy1dqFEypP0UKKYePCXdfQkeI2K7WeLmYEOsGOfpTSh9TBgD7JlxC1VKna5Ll+ghbYFBkxFEqQmfM2JWLb8lRcvZ8qAXpoecdRKVyCTOXXHprUwTcfWJj2/psE6kHzgaL9i+oGyc19yQVEAdyjqoSVKdtEfu7qPNOTst/wlWEz1o5VIrjkPzPUJTfvwFH6EadKvWzI4rHXinyaPGMzI7veZd1wB4H++pqrpYxW6H9nyxbUFdzOnrh+DHHUvTsyWhTvihWUR7BwlO9GRuD8C2O4MQm2M4KxEkD9YkuSVfLbQoLxzS7v3iSuojPWWArjfk1/iV+uppVm54LIMRrCMo2x9XHDuRITrgvV8L6bPu09VnjnPXEfRx+I7B1303w5SQr4QH2O3oMLmMU8sWrvhQkgvHWb2PkKzoat0nD0YYC4lM1o1yuBBDkQ0vmbM2+HEJg5vAIjHrONlyUWb0/vkc3FFtCQxlNTad1M6p3WXuK/6OenQJQFgupin9d5B2u2koENDChISZAJxklpGdOqx4foQjhWn6TzR4PwWOihkD/Mca1ZRzSyyhTCAJGmmTS3szazJvULJ+mlEEt7JkBlrbq3Cycr3XsO30y/cGE60oxwWg24RByH7qNPslnbztXH34ivZ4OoqUSN92oE3i926YUgNSWYcZNBoIZD28aGVGabTf2tpJ8YKEw9Qy+Pan9qog4G9GZgk4KWrgx3D8cXD+KRkg2cKRv08TE2AyBDEahR1sxma/n0iTIGHfLYtCHWdhiPFDZXEl3Tmi2tkkg98avuAcdUTWKhPbGrglRXrJflZ1GZQJtsfzSXpW95GDRuu3vsA5SXPZJZvaPjwYzcbVrkKvrWK24rU3K+eoGjMZpxUhdBTu1++d/OZ7hJfFFQ6fvAQFEM8NVmNd99SX+w5aHHhx7eQ1k1b3ZYDBhuK6nzR2jC29oFTJ+BrEZgyWjx/5AiNCoSBjLWh8jqqGcNivbX8BRMFygXkLKBK8br15dEKPXLDRd6GEJGb2DgusPZDfhkrIxUiuXCQgDAohA3gILy1+i2jMaf8G99j6rVCN/+Kx5NyW+Yt9LiaVxHXR9zNeEsX/uEjSmwdFOzp8G5cEZ4QEItLtYVqKrTZfPwgzIQvySYfoXWeYOFsT9P8oSBLaxCQOfQrg1/ycELkm5xecvTAkUlv1HWnKtXitMz8clGpvwGEQzsEzbH9fWdg7R+jq/U= X-OriginatorOrg: sct-15-20-4755-11-msonline-outlook-746f3.templateTenant X-MS-Exchange-CrossTenant-Network-Message-Id: e43c7130-83f5-42f8-8e31-08dc2338834e X-MS-Exchange-CrossTenant-AuthSource: MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 01 Feb 2024 15:14:41.2300 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-Transport-CrossTenantHeadersStamped: ME4P282MB1224 X-Patchwork-Delegate: kuba@kernel.org From: Jinjian Song To support cases such as FW update or Core dump, the t7xx device is capable of signaling the host that a special port needs to be created before the handshake phase. Adds the infrastructure required to create the early ports which also requires a different configuration of CLDMA queues. Base on the v5 patch version of follow series: 'net: wwan: t7xx: fw flashing & coredump support' (https://patchwork.kernel.org/project/netdevbpf/patch/3777bb382f4b0395cb594a602c5c79dbab86c9e0.1674307425.git.m.chetan.kumar@linux.intel.com/) Signed-off-by: Jinjian Song --- v7: * optimize fsm_routine_stopping() v5: * using t7xx_mode_update to update sysfs t7xx_mode v4: * change PORT_CH_ID_UNIMPORTANT to PORT_CH_UNIMPORTANT * delete t7xx_wait_pm_config() in t7xx_pci_pm_init() * define T7XX_MAX_POSSIBLE_PORTS_NUM to get max port num * define macro wait_for_expected_dev_stage to be more readable * change prev_status to status in struct t7xx_fsm_ctl --- drivers/net/wwan/t7xx/t7xx_hif_cldma.c | 47 +++++--- drivers/net/wwan/t7xx/t7xx_hif_cldma.h | 18 ++- drivers/net/wwan/t7xx/t7xx_modem_ops.c | 4 +- drivers/net/wwan/t7xx/t7xx_pci.c | 2 +- drivers/net/wwan/t7xx/t7xx_port.h | 4 + drivers/net/wwan/t7xx/t7xx_port_proxy.c | 105 ++++++++++++++--- drivers/net/wwan/t7xx/t7xx_port_proxy.h | 10 ++ drivers/net/wwan/t7xx/t7xx_port_wwan.c | 5 +- drivers/net/wwan/t7xx/t7xx_reg.h | 24 +++- drivers/net/wwan/t7xx/t7xx_state_monitor.c | 131 +++++++++++++++++---- drivers/net/wwan/t7xx/t7xx_state_monitor.h | 1 + 11 files changed, 290 insertions(+), 61 deletions(-) diff --git a/drivers/net/wwan/t7xx/t7xx_hif_cldma.c b/drivers/net/wwan/t7xx/t7xx_hif_cldma.c index cc70360364b7..abc41a7089fa 100644 --- a/drivers/net/wwan/t7xx/t7xx_hif_cldma.c +++ b/drivers/net/wwan/t7xx/t7xx_hif_cldma.c @@ -57,8 +57,6 @@ #define CHECK_Q_STOP_TIMEOUT_US 1000000 #define CHECK_Q_STOP_STEP_US 10000 -#define CLDMA_JUMBO_BUFF_SZ (63 * 1024 + sizeof(struct ccci_header)) - static void md_cd_queue_struct_reset(struct cldma_queue *queue, struct cldma_ctrl *md_ctrl, enum mtk_txrx tx_rx, unsigned int index) { @@ -161,7 +159,7 @@ static int t7xx_cldma_gpd_rx_from_q(struct cldma_queue *queue, int budget, bool skb_reset_tail_pointer(skb); skb_put(skb, le16_to_cpu(gpd->data_buff_len)); - ret = md_ctrl->recv_skb(queue, skb); + ret = queue->recv_skb(queue, skb); /* Break processing, will try again later */ if (ret < 0) return ret; @@ -897,13 +895,13 @@ static void t7xx_cldma_hw_start_send(struct cldma_ctrl *md_ctrl, int qno, /** * t7xx_cldma_set_recv_skb() - Set the callback to handle RX packets. - * @md_ctrl: CLDMA context structure. + * @queue: CLDMA queue. * @recv_skb: Receiving skb callback. */ -void t7xx_cldma_set_recv_skb(struct cldma_ctrl *md_ctrl, +void t7xx_cldma_set_recv_skb(struct cldma_queue *queue, int (*recv_skb)(struct cldma_queue *queue, struct sk_buff *skb)) { - md_ctrl->recv_skb = recv_skb; + queue->recv_skb = recv_skb; } /** @@ -993,6 +991,28 @@ int t7xx_cldma_send_skb(struct cldma_ctrl *md_ctrl, int qno, struct sk_buff *skb return ret; } +static void t7xx_cldma_adjust_config(struct cldma_ctrl *md_ctrl, enum cldma_cfg cfg_id) +{ + int qno; + + for (qno = 0; qno < CLDMA_RXQ_NUM; qno++) { + md_ctrl->rx_ring[qno].pkt_size = CLDMA_SHARED_Q_BUFF_SZ; + t7xx_cldma_set_recv_skb(&md_ctrl->rxq[qno], t7xx_port_proxy_recv_skb); + } + + md_ctrl->rx_ring[CLDMA_RXQ_NUM - 1].pkt_size = CLDMA_JUMBO_BUFF_SZ; + + for (qno = 0; qno < CLDMA_TXQ_NUM; qno++) + md_ctrl->tx_ring[qno].pkt_size = CLDMA_SHARED_Q_BUFF_SZ; + + if (cfg_id == CLDMA_DEDICATED_Q_CFG) { + md_ctrl->tx_ring[CLDMA_Q_IDX_DUMP].pkt_size = CLDMA_DEDICATED_Q_BUFF_SZ; + md_ctrl->rx_ring[CLDMA_Q_IDX_DUMP].pkt_size = CLDMA_DEDICATED_Q_BUFF_SZ; + t7xx_cldma_set_recv_skb(&md_ctrl->rxq[CLDMA_Q_IDX_DUMP], + t7xx_port_proxy_recv_skb_from_dedicated_queue); + } +} + static int t7xx_cldma_late_init(struct cldma_ctrl *md_ctrl) { char dma_pool_name[32]; @@ -1018,16 +1038,9 @@ static int t7xx_cldma_late_init(struct cldma_ctrl *md_ctrl) dev_err(md_ctrl->dev, "control TX ring init fail\n"); goto err_free_tx_ring; } - - md_ctrl->tx_ring[i].pkt_size = CLDMA_MTU; } for (j = 0; j < CLDMA_RXQ_NUM; j++) { - md_ctrl->rx_ring[j].pkt_size = CLDMA_MTU; - - if (j == CLDMA_RXQ_NUM - 1) - md_ctrl->rx_ring[j].pkt_size = CLDMA_JUMBO_BUFF_SZ; - ret = t7xx_cldma_rx_ring_init(md_ctrl, &md_ctrl->rx_ring[j]); if (ret) { dev_err(md_ctrl->dev, "Control RX ring init fail\n"); @@ -1094,6 +1107,7 @@ int t7xx_cldma_alloc(enum cldma_id hif_id, struct t7xx_pci_dev *t7xx_dev) { struct device *dev = &t7xx_dev->pdev->dev; struct cldma_ctrl *md_ctrl; + int qno; md_ctrl = devm_kzalloc(dev, sizeof(*md_ctrl), GFP_KERNEL); if (!md_ctrl) @@ -1102,7 +1116,9 @@ int t7xx_cldma_alloc(enum cldma_id hif_id, struct t7xx_pci_dev *t7xx_dev) md_ctrl->t7xx_dev = t7xx_dev; md_ctrl->dev = dev; md_ctrl->hif_id = hif_id; - md_ctrl->recv_skb = t7xx_cldma_default_recv_skb; + for (qno = 0; qno < CLDMA_RXQ_NUM; qno++) + md_ctrl->rxq[qno].recv_skb = t7xx_cldma_default_recv_skb; + t7xx_hw_info_init(md_ctrl); t7xx_dev->md->md_ctrl[hif_id] = md_ctrl; return 0; @@ -1332,9 +1348,10 @@ int t7xx_cldma_init(struct cldma_ctrl *md_ctrl) return -ENOMEM; } -void t7xx_cldma_switch_cfg(struct cldma_ctrl *md_ctrl) +void t7xx_cldma_switch_cfg(struct cldma_ctrl *md_ctrl, enum cldma_cfg cfg_id) { t7xx_cldma_late_release(md_ctrl); + t7xx_cldma_adjust_config(md_ctrl, cfg_id); t7xx_cldma_late_init(md_ctrl); } diff --git a/drivers/net/wwan/t7xx/t7xx_hif_cldma.h b/drivers/net/wwan/t7xx/t7xx_hif_cldma.h index 4410bac6993a..f2d9941be9c8 100644 --- a/drivers/net/wwan/t7xx/t7xx_hif_cldma.h +++ b/drivers/net/wwan/t7xx/t7xx_hif_cldma.h @@ -31,6 +31,10 @@ #include "t7xx_cldma.h" #include "t7xx_pci.h" +#define CLDMA_JUMBO_BUFF_SZ (63 * 1024 + sizeof(struct ccci_header)) +#define CLDMA_SHARED_Q_BUFF_SZ 3584 +#define CLDMA_DEDICATED_Q_BUFF_SZ 2048 + /** * enum cldma_id - Identifiers for CLDMA HW units. * @CLDMA_ID_MD: Modem control channel. @@ -55,6 +59,11 @@ struct cldma_gpd { __le16 not_used2; }; +enum cldma_cfg { + CLDMA_SHARED_Q_CFG, + CLDMA_DEDICATED_Q_CFG, +}; + struct cldma_request { struct cldma_gpd *gpd; /* Virtual address for CPU */ dma_addr_t gpd_addr; /* Physical address for DMA */ @@ -82,6 +91,7 @@ struct cldma_queue { wait_queue_head_t req_wq; /* Only for TX */ struct workqueue_struct *worker; struct work_struct cldma_work; + int (*recv_skb)(struct cldma_queue *queue, struct sk_buff *skb); }; struct cldma_ctrl { @@ -101,24 +111,22 @@ struct cldma_ctrl { struct md_pm_entity *pm_entity; struct t7xx_cldma_hw hw_info; bool is_late_init; - int (*recv_skb)(struct cldma_queue *queue, struct sk_buff *skb); }; +#define CLDMA_Q_IDX_DUMP 1 #define GPD_FLAGS_HWO BIT(0) #define GPD_FLAGS_IOC BIT(7) #define GPD_DMAPOOL_ALIGN 16 -#define CLDMA_MTU 3584 /* 3.5kB */ - int t7xx_cldma_alloc(enum cldma_id hif_id, struct t7xx_pci_dev *t7xx_dev); void t7xx_cldma_hif_hw_init(struct cldma_ctrl *md_ctrl); int t7xx_cldma_init(struct cldma_ctrl *md_ctrl); void t7xx_cldma_exit(struct cldma_ctrl *md_ctrl); -void t7xx_cldma_switch_cfg(struct cldma_ctrl *md_ctrl); +void t7xx_cldma_switch_cfg(struct cldma_ctrl *md_ctrl, enum cldma_cfg cfg_id); void t7xx_cldma_start(struct cldma_ctrl *md_ctrl); int t7xx_cldma_stop(struct cldma_ctrl *md_ctrl); void t7xx_cldma_reset(struct cldma_ctrl *md_ctrl); -void t7xx_cldma_set_recv_skb(struct cldma_ctrl *md_ctrl, +void t7xx_cldma_set_recv_skb(struct cldma_queue *queue, int (*recv_skb)(struct cldma_queue *queue, struct sk_buff *skb)); int t7xx_cldma_send_skb(struct cldma_ctrl *md_ctrl, int qno, struct sk_buff *skb); void t7xx_cldma_stop_all_qs(struct cldma_ctrl *md_ctrl, enum mtk_txrx tx_rx); diff --git a/drivers/net/wwan/t7xx/t7xx_modem_ops.c b/drivers/net/wwan/t7xx/t7xx_modem_ops.c index ca262d2961ed..fd79a2a1cc6f 100644 --- a/drivers/net/wwan/t7xx/t7xx_modem_ops.c +++ b/drivers/net/wwan/t7xx/t7xx_modem_ops.c @@ -535,7 +535,7 @@ static void t7xx_md_hk_wq(struct work_struct *work) /* Clear the HS2 EXIT event appended in core_reset() */ t7xx_fsm_clr_event(ctl, FSM_EVENT_MD_HS2_EXIT); - t7xx_cldma_switch_cfg(md->md_ctrl[CLDMA_ID_MD]); + t7xx_cldma_switch_cfg(md->md_ctrl[CLDMA_ID_MD], CLDMA_SHARED_Q_CFG); t7xx_cldma_start(md->md_ctrl[CLDMA_ID_MD]); t7xx_fsm_broadcast_state(ctl, MD_STATE_WAITING_FOR_HS2); md->core_md.handshake_ongoing = true; @@ -550,7 +550,7 @@ static void t7xx_ap_hk_wq(struct work_struct *work) /* Clear the HS2 EXIT event appended in t7xx_core_reset(). */ t7xx_fsm_clr_event(ctl, FSM_EVENT_AP_HS2_EXIT); t7xx_cldma_stop(md->md_ctrl[CLDMA_ID_AP]); - t7xx_cldma_switch_cfg(md->md_ctrl[CLDMA_ID_AP]); + t7xx_cldma_switch_cfg(md->md_ctrl[CLDMA_ID_AP], CLDMA_SHARED_Q_CFG); t7xx_cldma_start(md->md_ctrl[CLDMA_ID_AP]); md->core_ap.handshake_ongoing = true; t7xx_core_hk_handler(md, &md->core_ap, ctl, FSM_EVENT_AP_HS2, FSM_EVENT_AP_HS2_EXIT); diff --git a/drivers/net/wwan/t7xx/t7xx_pci.c b/drivers/net/wwan/t7xx/t7xx_pci.c index 1a10afd948c7..06e97778fd2f 100644 --- a/drivers/net/wwan/t7xx/t7xx_pci.c +++ b/drivers/net/wwan/t7xx/t7xx_pci.c @@ -183,7 +183,7 @@ static int t7xx_pci_pm_init(struct t7xx_pci_dev *t7xx_dev) pm_runtime_set_autosuspend_delay(&pdev->dev, PM_AUTOSUSPEND_MS); pm_runtime_use_autosuspend(&pdev->dev); - return t7xx_wait_pm_config(t7xx_dev); + return 0; } void t7xx_pci_pm_init_late(struct t7xx_pci_dev *t7xx_dev) diff --git a/drivers/net/wwan/t7xx/t7xx_port.h b/drivers/net/wwan/t7xx/t7xx_port.h index 4ae8a00a8532..f74d3bab810d 100644 --- a/drivers/net/wwan/t7xx/t7xx_port.h +++ b/drivers/net/wwan/t7xx/t7xx_port.h @@ -75,6 +75,8 @@ enum port_ch { PORT_CH_DSS6_TX = 0x20df, PORT_CH_DSS7_RX = 0x20e0, PORT_CH_DSS7_TX = 0x20e1, + + PORT_CH_UNIMPORTANT = 0xffff, }; struct t7xx_port; @@ -135,11 +137,13 @@ struct t7xx_port { }; }; +int t7xx_get_port_mtu(struct t7xx_port *port); struct sk_buff *t7xx_port_alloc_skb(int payload); struct sk_buff *t7xx_ctrl_alloc_skb(int payload); int t7xx_port_enqueue_skb(struct t7xx_port *port, struct sk_buff *skb); int t7xx_port_send_skb(struct t7xx_port *port, struct sk_buff *skb, unsigned int pkt_header, unsigned int ex_msg); +int t7xx_port_send_raw_skb(struct t7xx_port *port, struct sk_buff *skb); int t7xx_port_send_ctl_skb(struct t7xx_port *port, struct sk_buff *skb, unsigned int msg, unsigned int ex_msg); diff --git a/drivers/net/wwan/t7xx/t7xx_port_proxy.c b/drivers/net/wwan/t7xx/t7xx_port_proxy.c index 274846d39fbf..e53a152faee4 100644 --- a/drivers/net/wwan/t7xx/t7xx_port_proxy.c +++ b/drivers/net/wwan/t7xx/t7xx_port_proxy.c @@ -48,6 +48,9 @@ i < (proxy)->port_count; \ i++, (p) = &(proxy)->ports[i]) +#define T7XX_MAX_POSSIBLE_PORTS_NUM \ + (max(ARRAY_SIZE(t7xx_port_conf), ARRAY_SIZE(t7xx_early_port_conf))) + static const struct t7xx_port_conf t7xx_port_conf[] = { { .tx_ch = PORT_CH_UART2_TX, @@ -100,6 +103,18 @@ static const struct t7xx_port_conf t7xx_port_conf[] = { }, }; +static const struct t7xx_port_conf t7xx_early_port_conf[] = { + { + .tx_ch = PORT_CH_UNIMPORTANT, + .rx_ch = PORT_CH_UNIMPORTANT, + .txq_index = CLDMA_Q_IDX_DUMP, + .rxq_index = CLDMA_Q_IDX_DUMP, + .txq_exp_index = CLDMA_Q_IDX_DUMP, + .rxq_exp_index = CLDMA_Q_IDX_DUMP, + .path_id = CLDMA_ID_AP, + }, +}; + static struct t7xx_port *t7xx_proxy_get_port_by_ch(struct port_proxy *port_prox, enum port_ch ch) { const struct t7xx_port_conf *port_conf; @@ -214,7 +229,17 @@ int t7xx_port_enqueue_skb(struct t7xx_port *port, struct sk_buff *skb) return 0; } -static int t7xx_port_send_raw_skb(struct t7xx_port *port, struct sk_buff *skb) +int t7xx_get_port_mtu(struct t7xx_port *port) +{ + enum cldma_id path_id = port->port_conf->path_id; + int tx_qno = t7xx_port_get_queue_no(port); + struct cldma_ctrl *md_ctrl; + + md_ctrl = port->t7xx_dev->md->md_ctrl[path_id]; + return md_ctrl->tx_ring[tx_qno].pkt_size; +} + +int t7xx_port_send_raw_skb(struct t7xx_port *port, struct sk_buff *skb) { enum cldma_id path_id = port->port_conf->path_id; struct cldma_ctrl *md_ctrl; @@ -329,6 +354,39 @@ static void t7xx_proxy_setup_ch_mapping(struct port_proxy *port_prox) } } +/** + * t7xx_port_proxy_recv_skb_from_dedicated_queue() - Dispatch early port received skb. + * @queue: CLDMA queue. + * @skb: Socket buffer. + * + * Return: + ** 0 - Packet consumed. + ** -ERROR - Failed to process skb. + */ +int t7xx_port_proxy_recv_skb_from_dedicated_queue(struct cldma_queue *queue, struct sk_buff *skb) +{ + struct t7xx_pci_dev *t7xx_dev = queue->md_ctrl->t7xx_dev; + struct port_proxy *port_prox = t7xx_dev->md->port_prox; + const struct t7xx_port_conf *port_conf; + struct t7xx_port *port; + int ret; + + port = &port_prox->ports[0]; + if (WARN_ON_ONCE(port->port_conf->rxq_index != queue->index)) { + dev_kfree_skb_any(skb); + return -EINVAL; + } + + port_conf = port->port_conf; + ret = port_conf->ops->recv_skb(port, skb); + if (ret < 0 && ret != -ENOBUFS) { + dev_err(port->dev, "drop on RX ch %d, %d\n", port_conf->rx_ch, ret); + dev_kfree_skb_any(skb); + } + + return ret; +} + static struct t7xx_port *t7xx_port_proxy_find_port(struct t7xx_pci_dev *t7xx_dev, struct cldma_queue *queue, u16 channel) { @@ -359,7 +417,7 @@ static struct t7xx_port *t7xx_port_proxy_find_port(struct t7xx_pci_dev *t7xx_dev ** 0 - Packet consumed. ** -ERROR - Failed to process skb. */ -static int t7xx_port_proxy_recv_skb(struct cldma_queue *queue, struct sk_buff *skb) +int t7xx_port_proxy_recv_skb(struct cldma_queue *queue, struct sk_buff *skb) { struct ccci_header *ccci_h = (struct ccci_header *)skb->data; struct t7xx_pci_dev *t7xx_dev = queue->md_ctrl->t7xx_dev; @@ -444,33 +502,54 @@ static void t7xx_proxy_init_all_ports(struct t7xx_modem *md) spin_lock_init(&port->port_update_lock); port->chan_enable = false; - if (port_conf->ops->init) + if (port_conf->ops && port_conf->ops->init) port_conf->ops->init(port); } t7xx_proxy_setup_ch_mapping(port_prox); } +void t7xx_port_proxy_set_cfg(struct t7xx_modem *md, enum port_cfg_id cfg_id) +{ + struct port_proxy *port_prox = md->port_prox; + const struct t7xx_port_conf *port_conf; + u32 port_count; + int i; + + t7xx_port_proxy_uninit(port_prox); + + if (cfg_id == PORT_CFG_ID_EARLY) { + port_conf = t7xx_early_port_conf; + port_count = ARRAY_SIZE(t7xx_early_port_conf); + } else { + port_conf = t7xx_port_conf; + port_count = ARRAY_SIZE(t7xx_port_conf); + } + + for (i = 0; i < port_count; i++) + port_prox->ports[i].port_conf = &port_conf[i]; + + port_prox->cfg_id = cfg_id; + port_prox->port_count = port_count; + + t7xx_proxy_init_all_ports(md); +} + static int t7xx_proxy_alloc(struct t7xx_modem *md) { - unsigned int port_count = ARRAY_SIZE(t7xx_port_conf); struct device *dev = &md->t7xx_dev->pdev->dev; struct port_proxy *port_prox; - int i; - port_prox = devm_kzalloc(dev, sizeof(*port_prox) + sizeof(struct t7xx_port) * port_count, + port_prox = devm_kzalloc(dev, sizeof(*port_prox) + + sizeof(struct t7xx_port) * T7XX_MAX_POSSIBLE_PORTS_NUM, GFP_KERNEL); if (!port_prox) return -ENOMEM; md->port_prox = port_prox; port_prox->dev = dev; + t7xx_port_proxy_set_cfg(md, PORT_CFG_ID_EARLY); - for (i = 0; i < port_count; i++) - port_prox->ports[i].port_conf = &t7xx_port_conf[i]; - - port_prox->port_count = port_count; - t7xx_proxy_init_all_ports(md); return 0; } @@ -492,8 +571,6 @@ int t7xx_port_proxy_init(struct t7xx_modem *md) if (ret) return ret; - t7xx_cldma_set_recv_skb(md->md_ctrl[CLDMA_ID_AP], t7xx_port_proxy_recv_skb); - t7xx_cldma_set_recv_skb(md->md_ctrl[CLDMA_ID_MD], t7xx_port_proxy_recv_skb); return 0; } @@ -505,7 +582,7 @@ void t7xx_port_proxy_uninit(struct port_proxy *port_prox) for_each_proxy_port(i, port, port_prox) { const struct t7xx_port_conf *port_conf = port->port_conf; - if (port_conf->ops->uninit) + if (port_conf->ops && port_conf->ops->uninit) port_conf->ops->uninit(port); } } diff --git a/drivers/net/wwan/t7xx/t7xx_port_proxy.h b/drivers/net/wwan/t7xx/t7xx_port_proxy.h index 81d059fbc0fb..7f5706811445 100644 --- a/drivers/net/wwan/t7xx/t7xx_port_proxy.h +++ b/drivers/net/wwan/t7xx/t7xx_port_proxy.h @@ -31,11 +31,18 @@ #define RX_QUEUE_MAXLEN 32 #define CTRL_QUEUE_MAXLEN 16 +enum port_cfg_id { + PORT_CFG_ID_INVALID, + PORT_CFG_ID_NORMAL, + PORT_CFG_ID_EARLY, +}; + struct port_proxy { int port_count; struct list_head rx_ch_ports[PORT_CH_ID_MASK + 1]; struct list_head queue_ports[CLDMA_NUM][MTK_QUEUES]; struct device *dev; + enum port_cfg_id cfg_id; struct t7xx_port ports[]; }; @@ -98,5 +105,8 @@ void t7xx_port_proxy_md_status_notify(struct port_proxy *port_prox, unsigned int int t7xx_port_enum_msg_handler(struct t7xx_modem *md, void *msg); int t7xx_port_proxy_chl_enable_disable(struct port_proxy *port_prox, unsigned int ch_id, bool en_flag); +void t7xx_port_proxy_set_cfg(struct t7xx_modem *md, enum port_cfg_id cfg_id); +int t7xx_port_proxy_recv_skb(struct cldma_queue *queue, struct sk_buff *skb); +int t7xx_port_proxy_recv_skb_from_dedicated_queue(struct cldma_queue *queue, struct sk_buff *skb); #endif /* __T7XX_PORT_PROXY_H__ */ diff --git a/drivers/net/wwan/t7xx/t7xx_port_wwan.c b/drivers/net/wwan/t7xx/t7xx_port_wwan.c index 17389c8f6600..ddc20ddfa734 100644 --- a/drivers/net/wwan/t7xx/t7xx_port_wwan.c +++ b/drivers/net/wwan/t7xx/t7xx_port_wwan.c @@ -152,14 +152,15 @@ static int t7xx_port_wwan_disable_chl(struct t7xx_port *port) static void t7xx_port_wwan_md_state_notify(struct t7xx_port *port, unsigned int state) { const struct t7xx_port_conf *port_conf = port->port_conf; - unsigned int header_len = sizeof(struct ccci_header); + unsigned int header_len = sizeof(struct ccci_header), mtu; struct wwan_port_caps caps; if (state != MD_STATE_READY) return; if (!port->wwan.wwan_port) { - caps.frag_len = CLDMA_MTU - header_len; + mtu = t7xx_get_port_mtu(port); + caps.frag_len = mtu - header_len; caps.headroom_len = header_len; port->wwan.wwan_port = wwan_create_port(port->dev, port_conf->port_type, &wwan_ops, &caps, port); diff --git a/drivers/net/wwan/t7xx/t7xx_reg.h b/drivers/net/wwan/t7xx/t7xx_reg.h index c41d7d094c08..9c7dc72ac6f6 100644 --- a/drivers/net/wwan/t7xx/t7xx_reg.h +++ b/drivers/net/wwan/t7xx/t7xx_reg.h @@ -101,11 +101,33 @@ enum t7xx_pm_resume_state { PM_RESUME_REG_STATE_L2_EXP, }; +enum host_event_e { + HOST_EVENT_INIT = 0, + FASTBOOT_DL_NOTIFY = 0x3, +}; + #define T7XX_PCIE_MISC_DEV_STATUS 0x0d1c #define MISC_STAGE_MASK GENMASK(2, 0) #define MISC_RESET_TYPE_PLDR BIT(26) #define MISC_RESET_TYPE_FLDR BIT(27) -#define LINUX_STAGE 4 +#define MISC_RESET_TYPE_PLDR BIT(26) +#define MISC_LK_EVENT_MASK GENMASK(11, 8) +#define HOST_EVENT_MASK GENMASK(31, 28) + +enum lk_event_id { + LK_EVENT_NORMAL = 0, + LK_EVENT_CREATE_PD_PORT = 1, + LK_EVENT_CREATE_POST_DL_PORT = 2, + LK_EVENT_RESET = 7, +}; + +enum t7xx_device_stage { + T7XX_DEV_STAGE_INIT = 0, + T7XX_DEV_STAGE_BROM_PRE = 1, + T7XX_DEV_STAGE_BROM_POST = 2, + T7XX_DEV_STAGE_LK = 3, + T7XX_DEV_STAGE_LINUX = 4, +}; #define T7XX_PCIE_RESOURCE_STATUS 0x0d28 #define T7XX_PCIE_RESOURCE_STS_MSK GENMASK(4, 0) diff --git a/drivers/net/wwan/t7xx/t7xx_state_monitor.c b/drivers/net/wwan/t7xx/t7xx_state_monitor.c index c5d46f45fa62..b98ad4a1709b 100644 --- a/drivers/net/wwan/t7xx/t7xx_state_monitor.c +++ b/drivers/net/wwan/t7xx/t7xx_state_monitor.c @@ -47,6 +47,13 @@ #define FSM_MD_EX_PASS_TIMEOUT_MS 45000 #define FSM_CMD_TIMEOUT_MS 2000 +#define wait_for_expected_dev_stage(status) \ + read_poll_timeout(ioread32, status, \ + ((status & MISC_STAGE_MASK) == T7XX_DEV_STAGE_LINUX) || \ + ((status & MISC_STAGE_MASK) == T7XX_DEV_STAGE_LK), 100000, \ + 20000000, false, IREG_BASE(md->t7xx_dev) + \ + T7XX_PCIE_MISC_DEV_STATUS) + void t7xx_fsm_notifier_register(struct t7xx_modem *md, struct t7xx_fsm_notifier *notifier) { struct t7xx_fsm_ctl *ctl = md->fsm_ctl; @@ -206,6 +213,51 @@ static void fsm_routine_exception(struct t7xx_fsm_ctl *ctl, struct t7xx_fsm_comm fsm_finish_command(ctl, cmd, 0); } +static void t7xx_host_event_notify(struct t7xx_modem *md, unsigned int event_id) +{ + u32 value; + + value = ioread32(IREG_BASE(md->t7xx_dev) + T7XX_PCIE_MISC_DEV_STATUS); + value &= ~HOST_EVENT_MASK; + value |= FIELD_PREP(HOST_EVENT_MASK, event_id); + iowrite32(value, IREG_BASE(md->t7xx_dev) + T7XX_PCIE_MISC_DEV_STATUS); +} + +static void t7xx_lk_stage_event_handling(struct t7xx_fsm_ctl *ctl, unsigned int status) +{ + struct t7xx_modem *md = ctl->md; + struct cldma_ctrl *md_ctrl; + enum lk_event_id lk_event; + struct device *dev; + + dev = &md->t7xx_dev->pdev->dev; + lk_event = FIELD_GET(MISC_LK_EVENT_MASK, status); + switch (lk_event) { + case LK_EVENT_NORMAL: + case LK_EVENT_RESET: + break; + + case LK_EVENT_CREATE_PD_PORT: + case LK_EVENT_CREATE_POST_DL_PORT: + md_ctrl = md->md_ctrl[CLDMA_ID_AP]; + t7xx_cldma_hif_hw_init(md_ctrl); + t7xx_cldma_stop(md_ctrl); + t7xx_cldma_switch_cfg(md_ctrl, CLDMA_DEDICATED_Q_CFG); + + t7xx_cldma_start(md_ctrl); + + if (lk_event == LK_EVENT_CREATE_POST_DL_PORT) + t7xx_mode_update(md->t7xx_dev, T7XX_FASTBOOT_DL_MODE); + else + t7xx_mode_update(md->t7xx_dev, T7XX_FASTBOOT_DUMP_MODE); + break; + + default: + dev_err(dev, "Invalid LK event %d\n", lk_event); + break; + } +} + static int fsm_stopped_handler(struct t7xx_fsm_ctl *ctl) { ctl->curr_state = FSM_STATE_STOPPED; @@ -226,27 +278,32 @@ static void fsm_routine_stopped(struct t7xx_fsm_ctl *ctl, struct t7xx_fsm_comman static void fsm_routine_stopping(struct t7xx_fsm_ctl *ctl, struct t7xx_fsm_command *cmd) { - struct t7xx_pci_dev *t7xx_dev; - struct cldma_ctrl *md_ctrl; + struct cldma_ctrl *md_ctrl = ctl->md->md_ctrl[CLDMA_ID_MD]; + struct t7xx_pci_dev *t7xx_dev = ctl->md->t7xx_dev; + u32 mode = READ_ONCE(t7xx_dev->mode); int err; - if (ctl->curr_state == FSM_STATE_STOPPED || ctl->curr_state == FSM_STATE_STOPPING) { + if (ctl->curr_state == FSM_STATE_STOPPED || + ctl->curr_state == FSM_STATE_STOPPING || + mode == T7XX_RESET) { fsm_finish_command(ctl, cmd, -EINVAL); return; } - md_ctrl = ctl->md->md_ctrl[CLDMA_ID_MD]; - t7xx_dev = ctl->md->t7xx_dev; - ctl->curr_state = FSM_STATE_STOPPING; t7xx_fsm_broadcast_state(ctl, MD_STATE_WAITING_TO_STOP); t7xx_cldma_stop(md_ctrl); - if (!ctl->md->rgu_irq_asserted) { - t7xx_mhccif_h2d_swint_trigger(t7xx_dev, H2D_CH_DRM_DISABLE_AP); - /* Wait for the DRM disable to take effect */ - msleep(FSM_DRM_DISABLE_DELAY_MS); + if (mode == T7XX_FASTBOOT_DL_SWITCHING) + t7xx_host_event_notify(ctl->md, FASTBOOT_DL_NOTIFY); + + t7xx_mhccif_h2d_swint_trigger(t7xx_dev, H2D_CH_DRM_DISABLE_AP); + /* Wait for the DRM disable to take effect */ + msleep(FSM_DRM_DISABLE_DELAY_MS); + if (mode == T7XX_FASTBOOT_DL_SWITCHING) { + t7xx_mhccif_h2d_swint_trigger(t7xx_dev, H2D_CH_DEVICE_RESET); + } else { err = t7xx_acpi_fldr_func(t7xx_dev); if (err) t7xx_mhccif_h2d_swint_trigger(t7xx_dev, H2D_CH_DEVICE_RESET); @@ -318,7 +375,8 @@ static int fsm_routine_starting(struct t7xx_fsm_ctl *ctl) static void fsm_routine_start(struct t7xx_fsm_ctl *ctl, struct t7xx_fsm_command *cmd) { struct t7xx_modem *md = ctl->md; - u32 dev_status; + struct device *dev; + u32 status; int ret; if (!md) @@ -330,23 +388,53 @@ static void fsm_routine_start(struct t7xx_fsm_ctl *ctl, struct t7xx_fsm_command return; } + dev = &md->t7xx_dev->pdev->dev; ctl->curr_state = FSM_STATE_PRE_START; t7xx_md_event_notify(md, FSM_PRE_START); - ret = read_poll_timeout(ioread32, dev_status, - (dev_status & MISC_STAGE_MASK) == LINUX_STAGE, 20000, 2000000, - false, IREG_BASE(md->t7xx_dev) + T7XX_PCIE_MISC_DEV_STATUS); + ret = wait_for_expected_dev_stage(status); + if (ret) { - struct device *dev = &md->t7xx_dev->pdev->dev; + dev_err(dev, "read poll timeout %d\n", ret); + goto finish_command; + } - fsm_finish_command(ctl, cmd, -ETIMEDOUT); - dev_err(dev, "Invalid device status 0x%lx\n", dev_status & MISC_STAGE_MASK); - return; + if (status != ctl->status || cmd->flag != 0) { + u32 stage = FIELD_GET(MISC_STAGE_MASK, status); + + switch (stage) { + case T7XX_DEV_STAGE_INIT: + case T7XX_DEV_STAGE_BROM_PRE: + case T7XX_DEV_STAGE_BROM_POST: + dev_dbg(dev, "BROM_STAGE Entered\n"); + ret = t7xx_fsm_append_cmd(ctl, FSM_CMD_START, 0); + break; + + case T7XX_DEV_STAGE_LK: + dev_dbg(dev, "LK_STAGE Entered\n"); + t7xx_lk_stage_event_handling(ctl, status); + break; + + case T7XX_DEV_STAGE_LINUX: + dev_dbg(dev, "LINUX_STAGE Entered\n"); + t7xx_mhccif_mask_clr(md->t7xx_dev, D2H_INT_PORT_ENUM | + D2H_INT_ASYNC_MD_HK | D2H_INT_ASYNC_AP_HK); + if (cmd->flag == 0) + break; + t7xx_cldma_hif_hw_init(md->md_ctrl[CLDMA_ID_AP]); + t7xx_cldma_hif_hw_init(md->md_ctrl[CLDMA_ID_MD]); + t7xx_port_proxy_set_cfg(md, PORT_CFG_ID_NORMAL); + ret = fsm_routine_starting(ctl); + break; + + default: + break; + } + ctl->status = status; } - t7xx_cldma_hif_hw_init(md->md_ctrl[CLDMA_ID_AP]); - t7xx_cldma_hif_hw_init(md->md_ctrl[CLDMA_ID_MD]); - fsm_finish_command(ctl, cmd, fsm_routine_starting(ctl)); +finish_command: + fsm_finish_command(ctl, cmd, ret); } static int fsm_main_thread(void *data) @@ -518,6 +606,7 @@ void t7xx_fsm_reset(struct t7xx_modem *md) fsm_flush_event_cmd_qs(ctl); ctl->curr_state = FSM_STATE_STOPPED; ctl->exp_flg = false; + ctl->status = T7XX_DEV_STAGE_INIT; } int t7xx_fsm_init(struct t7xx_modem *md) diff --git a/drivers/net/wwan/t7xx/t7xx_state_monitor.h b/drivers/net/wwan/t7xx/t7xx_state_monitor.h index b0b3662ae6d7..7b0a9baf488c 100644 --- a/drivers/net/wwan/t7xx/t7xx_state_monitor.h +++ b/drivers/net/wwan/t7xx/t7xx_state_monitor.h @@ -96,6 +96,7 @@ struct t7xx_fsm_ctl { bool exp_flg; spinlock_t notifier_lock; /* Protects notifier list */ struct list_head notifier_list; + u32 status; /* Device boot stage */ }; struct t7xx_fsm_event { From patchwork Thu Feb 1 15:13:40 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jinjian Song X-Patchwork-Id: 13541214 X-Patchwork-Delegate: kuba@kernel.org Received: from AUS01-ME3-obe.outbound.protection.outlook.com (mail-me3aus01olkn2159.outbound.protection.outlook.com [40.92.63.159]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 122A05F496 for ; Thu, 1 Feb 2024 15:15:10 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.92.63.159 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706800513; cv=fail; b=T7WzWD/VIcf6R0ksFBe07DXhzcg3I9E/VtPxTMHiEut0noRe+T0WIjoqYlgw5BDCGBwV7FgZfi2GyFRDBPBXLmPImesZjUWFDBeqOhFk+TKvxmm6i5GjEl9KQa0wQjP68+NZDWMySQWpjIARpBkMhOjEOm/m/t+P2uI6oiHjppg= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706800513; c=relaxed/simple; bh=gf9LhBs0ZYm1Mn5O4XujTk6UR1kl2CoA/JT6IteD6rg=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=ZK426bFueMFExtwUz0B7CJN4Yjp/zgudF0fhuwqRGSSrckOS2Ott+Fo6dtANfOK3ov8Am+zOmadl4b8x7iaevzmzcjkfvZXn0sMxNY2ApcnKkxORsnlH+5DjlXu3Y08GWgzB3SdOqZrglnmLITqFtq8kBr1BltP6IEkhTq/IbdU= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=hotmail.com; spf=pass smtp.mailfrom=hotmail.com; dkim=pass (2048-bit key) header.d=hotmail.com header.i=@hotmail.com header.b=e7eYKMhz; arc=fail smtp.client-ip=40.92.63.159 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=hotmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=hotmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=hotmail.com header.i=@hotmail.com header.b="e7eYKMhz" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=XA0YZH3uxTtxmlxpGpe/GOXQPDVFjvxNf3r64Tkba69SJWoTvFer8TSBdrlnfwXl6XQju9nNWXKwhDlh3I5/0jfPBabquics7QxB+wmViKYHAp/TrGscx3OZ/eXzb5+BUQKVvL3Uj+hFhD9bB5ISAVGZgLPwaCGemTM8UKCGWFuBXeyTKJSkK6huWbqbnjJOJy/BPEEdBeGX1EkjIPylNy3PFfZsLc03D9zST0x2Q9r2vRe5lsWsdoedyYAGx1/bacmgeU0ho+Cj9ypv8daVfHR3K7HVuH5RcMjwm++qkiORS5kscDS+BWNB0gBJpIOQ6szxPJEoQnEImZn1Tn76kA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=uj4KJk/MfnGI3RhRBDrr5qWs3RycLRSjzB8e+fw+YXw=; b=i4IUyiI0GjBnWQxX3LdJ3Ee1RSESuDC3SEpCbSH0mB/mrr1lsxb4xsj1OHYkdokfP8YBmb+HbPzq0I2Kcki/9LBaH15Jd59OH7I411RfXJstgJN6c2B2wdNcQLq76oqA+Zh8tqSAOJ2m1Gv2ybw8yagu8xt/9XQZO01e1SJBP9aB8ZZAmXCig6BlPh/iXpBRgptjjHsrGszIxJzLtReflkJXEePYW8O8eNTEbE8J5MnJxZr3nBjpUnuVxh+aCwc5vPAB2sBP2wjWJDqO5yoRLs294/2bYO22MPFS5WmREt+ZT0N3Phn4mutFGTTtGb1o9nsOlyff5qjOognAM5R75A== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none; dmarc=none; dkim=none; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=hotmail.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=uj4KJk/MfnGI3RhRBDrr5qWs3RycLRSjzB8e+fw+YXw=; b=e7eYKMhzSToHHbN/4j+/l8cQwLSy7iH6sLPtMFWEFo6r2eyiPzH8m2sKajZuO3dHif8CsDC0hWcMj/L7kYhtN0jokFuxHGwRXOUpKdib1g7kVzD3LthjzKmP+AgbMFKtHVP18jJwsyJPqpeQNSY3GApUs/O8nBIlP7um++ybqbJSyqeU781sUbtyj2FZRZx9hV0qVHIEeSRBsc/qE7VmttsMmXbmmx7HLc4EooS2Ibtam6MhNS5RKtGjxgC0QhbMxxdeIFvcVLox6HrLRlFIN9Y50ijcUpr8lI7vyADo1EGW1fH+pqSJh1bC67NZWD1CrNyHuQwvxaBs2/sSrqMu3A== Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) by ME4P282MB1224.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:9a::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7249.26; Thu, 1 Feb 2024 15:14:51 +0000 Received: from MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::4b5:c5db:e39a:e48f]) by MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM ([fe80::4b5:c5db:e39a:e48f%4]) with mapi id 15.20.7249.025; Thu, 1 Feb 2024 15:14:51 +0000 From: Jinjian Song To: netdev@vger.kernel.org Cc: chandrashekar.devegowda@intel.com, chiranjeevi.rapolu@linux.intel.com, haijun.liu@mediatek.com, m.chetan.kumar@linux.intel.com, ricardo.martinez@linux.intel.com, loic.poulain@linaro.org, ryazanov.s.a@gmail.com, johannes@sipsolutions.net, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, linux-kernel@vger.kernel.com, vsankar@lenovo.com, letitia.tsai@hp.com, pin-hao.huang@hp.com, danielwinkler@google.com, nmarupaka@google.com, joey.zhao@fibocom.com, liuqf@fibocom.com, felix.yan@fibocom.com, angel.huang@fibocom.com, freddy.lin@fibocom.com, alan.zhang1@fibocom.com, zhangrc@fibocom.com, Jinjian Song Subject: [net-next v7 4/4] net: wwan: t7xx: Add fastboot WWAN port Date: Thu, 1 Feb 2024 23:13:40 +0800 Message-ID: X-Mailer: git-send-email 2.34.1 In-Reply-To: <20240201151340.4963-1-songjinjian@hotmail.com> References: <20240201151340.4963-1-songjinjian@hotmail.com> X-TMN: [3cJAv3wca4LfTC5gk0jkXbYwqznIusXJ] X-ClientProxiedBy: TY2PR04CA0004.apcprd04.prod.outlook.com (2603:1096:404:f6::16) To MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM (2603:10c6:220:14c::12) X-Microsoft-Original-Message-ID: <20240201151340.4963-5-songjinjian@hotmail.com> Precedence: bulk X-Mailing-List: netdev@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: MEYP282MB2697:EE_|ME4P282MB1224:EE_ X-MS-Office365-Filtering-Correlation-Id: d36c9969-b4f1-448b-bdb5-08dc233888d7 X-MS-Exchange-SLBlob-MailProps: iS5pQZgsAQDnmM4WfgbAB22eBPSSfRfjSXkIKqbedHf+KffmgjoLMx/ItZgQwrnayLxg/1NVBoA1smRTUXeX66r/UNK7pG+OKqVFJPR7PiNe4q5Grvrh9wUlWA/a/imkzrht4CtbE7JAk3SjPG65y9ETIRVsaX+4O4ujhK7xIaTNkZB0ZvyaqAuzBpKHyGZp88+v3QnSyRDyyZNp/bATJXBDservfyPOiVAhp9Ps6xN2q5jVgbld6vjyXkZWS4EQJeQYnogY6ajd94cZqfO0QGqgt85bmiN9IQ3TvbwBtdQGbJoMSjgRNuYvIDfVRzzffBM/tZkWyPmJN5Da0k+PClE1GaCI3ajUBfRN3VPF0IAiFxhzYORajXeqi/Ksx/zrSXTH1UR5p7IvjUvrVv77lLt7nDMWjLM04n+VniF3OJMZwSShvNe6TQxicieAJWxfKVmb2+Ass8h7jJVQKHJQfDzWr5ZxNRh5lw/ZfBwOWtRw499VLNZmBhhOUf3Dh5agD4N78PMFY1b9erVuge7wzWziP3b/Yk8LCjd7gmt2x0smiwEsUucsz6liZeMBhPJNQqv+E33p8KWwvwQH3QRIK8RJE/yJx4hjoT64FpmVn5fLhRORa0jsoL5I7KhDxuBXTrl4g7xapZivjDGlqOzR2uLA5TZaCBZ8GoINYJBAyE55V8s33CuWbNoNuYShMtr7IuDj4OlVP8d1AUI0Lub34knrfH04DzSakMfW1nDS47AqKrOFP0SlxF/6jjXENWzOEbC0e4Ho3HyQlaR1WkgMeVi+UD5XsbZc9qFY2V5TOjM/ZnmSVFHmXcqMWX0D0sQ/ X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: C5/y30wehcCN/JUP8oZwkeOltJouEUtXgE+DC0hc0fsEvhTxOa4TxHZQ7PSZu2Dy5zR1h9IzidZJs23845JNBD9rr0MHKgxgbaCEu7KdtL6/6uKbV1xddksTFkMdKnmS1DqWdW0IgLCm+Wtmn6gLb80TvfxNraGmbPqusBJce9JXHjQPzh+tJgXOj+nqbBIHhOZlEg4AaBRDbNY983Wc4VesOnNbLBvJoYjznu/dXZgyN6PRC6zdvUrU6cAsfHfI4MZb6jektvKDAL2hiZEESLewAj0KeKVoS957YzxvJzOw0yzPUim2Xydt/H706PhvkhhJ+JSjwa5rKLVHwU35mBrjRMhCFS84ieZV+uu+RNHxpGMHo1LH8zWubT4mnseLyDzH0nRL17oxIql8dDWzWZiKJtTV9i+QjUH4VRVxX5dAC+lv0FxGVR8srOzcmsVoGfzXQOv1mWMKvGJKWyK0ThLgehTzwLRkRCcQ+ZHrkSzcOkgi5h02lvHHYR1o2XYagUmpCvVTPh05a70FWvYBIdUlTVgIFjq9DsJ6r3EZ3EtanQgQf1Crgl6puOdY5BOUi2G9H1R8kHVX25S2CPv7nvjAZ1kFjjkTMFQba25Y7wI= X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: aepvV8IiOtOWxMzGwC6hJWfQMK5tpWuG1PcS4NKeIKkD5SchUsy78bXQNIDAP8JcEdyEwjza02+uyu9PZP68cfTXXogf6XSCIndJAZLRgPO4tlIWMbzRmZfTt8md981S3+UqozJy9Pz+mp+yDTqVoJuA80JRv+foOfTqZd44rn0F5P6WzF+ihkeBEhimg7FK6wWhQzlkZwKLJj5RrDfDfC4BAYdy7GxxqAr8BkUKJT/4FjNpvudYlaavwrqpUfMlLu1qtVsSIYyn/XU9SVjB84fp+D1QgXHuG78Eb1DxI/WODh6Qv7tkYbWfAJGnqkJjUCaNTgaCw+5JFyJljhyJOn6Y4a6M0SuFdrJ77PhfC34OZrXqClNmjPYCcpnHu9Ts/AfqCR49RrqElypjFf4tlQvDaciiCm0u2YgeX9F8N26RhE70AA2KJKA13Z9Bw86pTRxjtffdtoZDLd37xJp6bDltMZqY+5qDmVGKn2nXIjV6X0rhiI8wLL03jyD48ynnqiUVYlSYGOL+PX0XsMJF0xsDKtwOxNbWLAcvakFYlCJ+6LjbzyTYM4O2yJBzTKfqYOYgiO6KQ14kjmcvtzGowDZT/0s9vOrTpa2pQ6yZmZIvUrti5QBXZdlLOrDHYLfdD3+Wgqc/P1mP/h17c7gedKhrEtcaFFnn2MHU3j+Q6JiggyiasTa7w49lVdWwA5wEMubXja8xddyajN5e12cGog2j4ioJcnajbBnWDcO2+wFVq7p5T+btPkQtRCTJfeaheATQaTmQt9z5sFUkEUhhwinm7I8RO1tUgWEiyVErMQlMa6YFMsr2hhaYKkyf00RjwbvSRRFrlQqWLlAkWc/yhe5UFrpcRKn/oaGKbk7N2Zk3ho3nB+5BrQpSMsbV9KQU1hIhlgVLhg51oTCD1nHlmSS7f2OpS00tBIrzjKoBIelINOtB0dtoFLc5Ttw2DMLxHaacMBdATYNaB3Nycdy6Fl/vKvjeN+OJLCvBgIPp0u20FyKA3APia/M+AaLLb7I778gojgYb5OtlIdQqnxCOQh39kGS1DwxnZHD09MS6F06lhIPOziafc9IDv70rHNEbU5Zag9rClbwzbLErBHTBjOVRSLPG2jy/2hQiMPY2n2s06ai9KN6FLkvbuQCFUilsMs9Lo0bd3mwZVnA4UoviLjXe/s0xHN4i44gP+nzRSQjdV5nVAkyCi487HhKspxYUf+Xd4IXHahnZCGlBIpiSo6I0yu0YCIxHSZj4G7Hv0F0= X-OriginatorOrg: sct-15-20-4755-11-msonline-outlook-746f3.templateTenant X-MS-Exchange-CrossTenant-Network-Message-Id: d36c9969-b4f1-448b-bdb5-08dc233888d7 X-MS-Exchange-CrossTenant-AuthSource: MEYP282MB2697.AUSP282.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 01 Feb 2024 15:14:50.5739 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-Transport-CrossTenantHeadersStamped: ME4P282MB1224 X-Patchwork-Delegate: kuba@kernel.org From: Jinjian Song On early detection of wwan device in fastboot mode, driver sets up CLDMA0 HW tx/rx queues for raw data transfer and then create fastboot port to userspace. Application can use this port to flash firmware and collect core dump by fastboot protocol commands. E.g., flash firmware through fastboot port: - "download:%08x": write data to memory with the download size. - "flash:%s": write the previously downloaded image to the named partition. - "reboot": reboot the device. Link: https://android.googlesource.com/platform/system/core/+/refs/heads/main/fastboot/README.md Signed-off-by: Jinjian Song --- v7: * add fastboot protocol link and command description to commit info v6: * reorganize code to avoid dumplication v4: * change function prefix to t7xx_port_fastboot * change the name 'FASTBOOT' to fastboot in struct t7xx_early_port_conf --- .../networking/device_drivers/wwan/t7xx.rst | 14 +++ drivers/net/wwan/t7xx/t7xx_port_proxy.c | 3 + drivers/net/wwan/t7xx/t7xx_port_wwan.c | 116 ++++++++++++++---- drivers/net/wwan/t7xx/t7xx_state_monitor.c | 4 + 4 files changed, 111 insertions(+), 26 deletions(-) diff --git a/Documentation/networking/device_drivers/wwan/t7xx.rst b/Documentation/networking/device_drivers/wwan/t7xx.rst index d13624a52d8b..7257ede90152 100644 --- a/Documentation/networking/device_drivers/wwan/t7xx.rst +++ b/Documentation/networking/device_drivers/wwan/t7xx.rst @@ -125,6 +125,20 @@ The driver exposes an AT port by implementing AT WWAN Port. The userspace end of the control port is a /dev/wwan0at0 character device. Application shall use this interface to issue AT commands. +fastboot port userspace ABI +--------------------------- + +/dev/wwan0fastboot0 character device +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +The driver exposes a fastboot protocol interface by implementing +fastboot WWAN Port. The userspace end of the fastboot channel pipe is a +/dev/wwan0fastboot0 character device. Application shall use this interface for +fastboot protocol communication. + +Please note that driver needs to be reloaded to export /dev/wwan0fastboot0 +port, because device needs a cold reset after enter ``FASTBOOT_DL_SWITCHING`` +mode. + The MediaTek's T700 modem supports the 3GPP TS 27.007 [4] specification. References diff --git a/drivers/net/wwan/t7xx/t7xx_port_proxy.c b/drivers/net/wwan/t7xx/t7xx_port_proxy.c index e53a152faee4..8f5e01705af2 100644 --- a/drivers/net/wwan/t7xx/t7xx_port_proxy.c +++ b/drivers/net/wwan/t7xx/t7xx_port_proxy.c @@ -112,6 +112,9 @@ static const struct t7xx_port_conf t7xx_early_port_conf[] = { .txq_exp_index = CLDMA_Q_IDX_DUMP, .rxq_exp_index = CLDMA_Q_IDX_DUMP, .path_id = CLDMA_ID_AP, + .ops = &wwan_sub_port_ops, + .name = "fastboot", + .port_type = WWAN_PORT_FASTBOOT, }, }; diff --git a/drivers/net/wwan/t7xx/t7xx_port_wwan.c b/drivers/net/wwan/t7xx/t7xx_port_wwan.c index ddc20ddfa734..1d3372848cb6 100644 --- a/drivers/net/wwan/t7xx/t7xx_port_wwan.c +++ b/drivers/net/wwan/t7xx/t7xx_port_wwan.c @@ -2,6 +2,7 @@ /* * Copyright (c) 2021, MediaTek Inc. * Copyright (c) 2021-2022, Intel Corporation. + * Copyright (c) 2024, Fibocom Wireless Inc. * * Authors: * Amir Hanania @@ -15,6 +16,7 @@ * Chiranjeevi Rapolu * Eliot Lee * Sreehari Kancharla + * Jinjian Song */ #include @@ -33,7 +35,7 @@ #include "t7xx_port_proxy.h" #include "t7xx_state_monitor.h" -static int t7xx_port_ctrl_start(struct wwan_port *port) +static int t7xx_port_wwan_start(struct wwan_port *port) { struct t7xx_port *port_mtk = wwan_port_get_drvdata(port); @@ -44,30 +46,60 @@ static int t7xx_port_ctrl_start(struct wwan_port *port) return 0; } -static void t7xx_port_ctrl_stop(struct wwan_port *port) +static void t7xx_port_wwan_stop(struct wwan_port *port) { struct t7xx_port *port_mtk = wwan_port_get_drvdata(port); atomic_dec(&port_mtk->usage_cnt); } -static int t7xx_port_ctrl_tx(struct wwan_port *port, struct sk_buff *skb) +static int t7xx_port_fastboot_tx(struct t7xx_port *port, struct sk_buff *skb) +{ + struct sk_buff *cur = skb, *tx_skb; + size_t actual, len, offset = 0; + int txq_mtu; + int ret; + + txq_mtu = t7xx_get_port_mtu(port); + if (txq_mtu < 0) + return -EINVAL; + + actual = cur->len; + while (actual) { + len = min_t(size_t, actual, txq_mtu); + tx_skb = __dev_alloc_skb(len, GFP_KERNEL); + if (!tx_skb) + return -ENOMEM; + + skb_put_data(tx_skb, cur->data + offset, len); + + ret = t7xx_port_send_raw_skb(port, tx_skb); + if (ret) { + dev_kfree_skb(tx_skb); + dev_err(port->dev, "Write error on fastboot port, %d\n", ret); + break; + } + offset += len; + actual -= len; + } + + dev_kfree_skb(skb); + return 0; +} + +static int t7xx_port_ctrl_tx(struct t7xx_port *port, struct sk_buff *skb) { - struct t7xx_port *port_private = wwan_port_get_drvdata(port); const struct t7xx_port_conf *port_conf; struct sk_buff *cur = skb, *cloned; struct t7xx_fsm_ctl *ctl; enum md_state md_state; int cnt = 0, ret; - if (!port_private->chan_enable) - return -EINVAL; - - port_conf = port_private->port_conf; - ctl = port_private->t7xx_dev->md->fsm_ctl; + port_conf = port->port_conf; + ctl = port->t7xx_dev->md->fsm_ctl; md_state = t7xx_fsm_get_md_state(ctl); if (md_state == MD_STATE_WAITING_FOR_HS1 || md_state == MD_STATE_WAITING_FOR_HS2) { - dev_warn(port_private->dev, "Cannot write to %s port when md_state=%d\n", + dev_warn(port->dev, "Cannot write to %s port when md_state=%d\n", port_conf->name, md_state); return -ENODEV; } @@ -75,10 +107,10 @@ static int t7xx_port_ctrl_tx(struct wwan_port *port, struct sk_buff *skb) while (cur) { cloned = skb_clone(cur, GFP_KERNEL); cloned->len = skb_headlen(cur); - ret = t7xx_port_send_skb(port_private, cloned, 0, 0); + ret = t7xx_port_send_skb(port, cloned, 0, 0); if (ret) { dev_kfree_skb(cloned); - dev_err(port_private->dev, "Write error on %s port, %d\n", + dev_err(port->dev, "Write error on %s port, %d\n", port_conf->name, ret); return cnt ? cnt + ret : ret; } @@ -93,14 +125,53 @@ static int t7xx_port_ctrl_tx(struct wwan_port *port, struct sk_buff *skb) return 0; } +static int t7xx_port_wwan_tx(struct wwan_port *port, struct sk_buff *skb) +{ + struct t7xx_port *port_private = wwan_port_get_drvdata(port); + const struct t7xx_port_conf *port_conf = port_private->port_conf; + int ret; + + if (!port_private->chan_enable) + return -EINVAL; + + if (port_conf->port_type != WWAN_PORT_FASTBOOT) + ret = t7xx_port_ctrl_tx(port_private, skb); + else + ret = t7xx_port_fastboot_tx(port_private, skb); + + return ret; +} + static const struct wwan_port_ops wwan_ops = { - .start = t7xx_port_ctrl_start, - .stop = t7xx_port_ctrl_stop, - .tx = t7xx_port_ctrl_tx, + .start = t7xx_port_wwan_start, + .stop = t7xx_port_wwan_stop, + .tx = t7xx_port_wwan_tx, }; +static void t7xx_port_wwan_create(struct t7xx_port *port) +{ + const struct t7xx_port_conf *port_conf = port->port_conf; + unsigned int header_len = sizeof(struct ccci_header), mtu; + struct wwan_port_caps caps; + + if (!port->wwan.wwan_port) { + mtu = t7xx_get_port_mtu(port); + caps.frag_len = mtu - header_len; + caps.headroom_len = header_len; + port->wwan.wwan_port = wwan_create_port(port->dev, port_conf->port_type, + &wwan_ops, &caps, port); + if (IS_ERR(port->wwan.wwan_port)) + dev_err(port->dev, "Unable to create WWWAN port %s", port_conf->name); + } +} + static int t7xx_port_wwan_init(struct t7xx_port *port) { + const struct t7xx_port_conf *port_conf = port->port_conf; + + if (port_conf->port_type == WWAN_PORT_FASTBOOT) + t7xx_port_wwan_create(port); + port->rx_length_th = RX_QUEUE_MAXLEN; return 0; } @@ -152,21 +223,14 @@ static int t7xx_port_wwan_disable_chl(struct t7xx_port *port) static void t7xx_port_wwan_md_state_notify(struct t7xx_port *port, unsigned int state) { const struct t7xx_port_conf *port_conf = port->port_conf; - unsigned int header_len = sizeof(struct ccci_header), mtu; - struct wwan_port_caps caps; + + if (port_conf->port_type == WWAN_PORT_FASTBOOT) + return; if (state != MD_STATE_READY) return; - if (!port->wwan.wwan_port) { - mtu = t7xx_get_port_mtu(port); - caps.frag_len = mtu - header_len; - caps.headroom_len = header_len; - port->wwan.wwan_port = wwan_create_port(port->dev, port_conf->port_type, - &wwan_ops, &caps, port); - if (IS_ERR(port->wwan.wwan_port)) - dev_err(port->dev, "Unable to create WWWAN port %s", port_conf->name); - } + t7xx_port_wwan_create(port); } struct port_ops wwan_sub_port_ops = { diff --git a/drivers/net/wwan/t7xx/t7xx_state_monitor.c b/drivers/net/wwan/t7xx/t7xx_state_monitor.c index b98ad4a1709b..11906f00c875 100644 --- a/drivers/net/wwan/t7xx/t7xx_state_monitor.c +++ b/drivers/net/wwan/t7xx/t7xx_state_monitor.c @@ -229,6 +229,7 @@ static void t7xx_lk_stage_event_handling(struct t7xx_fsm_ctl *ctl, unsigned int struct cldma_ctrl *md_ctrl; enum lk_event_id lk_event; struct device *dev; + struct t7xx_port *port; dev = &md->t7xx_dev->pdev->dev; lk_event = FIELD_GET(MISC_LK_EVENT_MASK, status); @@ -244,6 +245,9 @@ static void t7xx_lk_stage_event_handling(struct t7xx_fsm_ctl *ctl, unsigned int t7xx_cldma_stop(md_ctrl); t7xx_cldma_switch_cfg(md_ctrl, CLDMA_DEDICATED_Q_CFG); + port = &ctl->md->port_prox->ports[0]; + port->port_conf->ops->enable_chl(port); + t7xx_cldma_start(md_ctrl); if (lk_event == LK_EVENT_CREATE_POST_DL_PORT)