From patchwork Mon Nov 27 12:45:20 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Manivannan Sadhasivam X-Patchwork-Id: 17140 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:ce62:0:b0:403:3b70:6f57 with SMTP id o2csp3075713vqx; Mon, 27 Nov 2023 04:47:18 -0800 (PST) X-Google-Smtp-Source: AGHT+IGw41fX5zgfkm7TA2GGoxTSxVhOuM+ThKW0gdnga/EnWlFsk3YYquvlsDGXEgYaSSQFvseF X-Received: by 2002:a17:90b:3846:b0:285:9408:2fb8 with SMTP id nl6-20020a17090b384600b0028594082fb8mr9351453pjb.43.1701089237767; Mon, 27 Nov 2023 04:47:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701089237; cv=none; d=google.com; s=arc-20160816; b=q5F9TTiJJh2EEQcYDrYpaBCk1IH42bZsehxndUO5CH+nLgWhnMYb+X9UWqA3eOimN1 77AggIZj69WMX2BZPOc8s87A1w4YgWiOu9sMjohZUi8wSz8/lEC90q4ak+c9EKVIQAuh Jbc2HvA1aRLnV4akEVmANjy3xlxpQo8OtIV+ODNNsUpkh7kqXR0X5Rcctm4XunoU+NIj DnYvLonn8U2SdjZe+F2KVTTNDehb04FJ/6W2CQRd7IAXXWqTRnfxq0+oZNgU7Qzp196H P8Q7iAMe1an2p7CJ+OKSRdoXf/S8f/r9pCQjQi0JPTY/tJT77mzQHfzVyLcmcScITONo vWIA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=My7gSFRp+Y7hoOV+FBK21Q8iK89AnBNbYhuMMj6/9YA=; fh=GCPsaS9gPzUx9ecgCkAchNprj2XO1a7aLVETzufn50Y=; b=Rl18hAzQVTjHzrtZ7mvbUr0t7jL2h+EGQTTIrEYEKBAxmBMYW+/9NCUvwhUZaW7F7j cDT94J2qpPwGG11iZ0rgA534/iak2IHFL8MTb0xK2x+ojVvZWwQKslgs4L7ubTFi9n4f vpq2fI827iKdGJAfqQfUuTqnrneWtC/FzuD60RLX7YqFX8pIn3ZQ9Y3WVhA307clLn6o xP0VGbl9JroYPVsnEDKDaWujIjoVkI3KGdbr0spf2mMsZZ8VhAzLLIaBSif/bw99QNv0 f6ld0PWPPH0S8mVAvnuYV1qTXVXNC72zxXuD+QTVBzoaMECaW31EqgiZlGkCznta1vJQ oxWQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=nq8c2ZQ2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id k61-20020a17090a3ec300b00285a8cd2d33si4855045pjc.172.2023.11.27.04.47.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 27 Nov 2023 04:47:17 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=nq8c2ZQ2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id 2315380841C3; Mon, 27 Nov 2023 04:46:04 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233387AbjK0Mpk (ORCPT + 99 others); Mon, 27 Nov 2023 07:45:40 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43918 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233192AbjK0Mpi (ORCPT ); Mon, 27 Nov 2023 07:45:38 -0500 Received: from mail-qk1-x729.google.com (mail-qk1-x729.google.com [IPv6:2607:f8b0:4864:20::729]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2F5D010F for ; Mon, 27 Nov 2023 04:45:44 -0800 (PST) Received: by mail-qk1-x729.google.com with SMTP id af79cd13be357-77d84f8808dso139748885a.2 for ; Mon, 27 Nov 2023 04:45:44 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1701089143; x=1701693943; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=My7gSFRp+Y7hoOV+FBK21Q8iK89AnBNbYhuMMj6/9YA=; b=nq8c2ZQ2iSF2Iu1oeCXn1TmpOK9wA//99CcvtoPaue8jEu34xZewQr/FOqKtlyXOvM LFPOti7AhKNQbW6rCNst3etX9twZ2x+FOzOM9qDoduhn6Dkdd3mIV2nlqz3wu1xGEB0q F7eGUEg+oJPYkKqEm0P/TVpu7AG8ZuevnFpaiv4WrpJxoWg5wfBP+1BiNf3Cfp3ByBJb Qamtj5LlliWbprW14a7hPYCygiBUZhm7i+tJYIBlJ6I+MiVT8/VwgkOy2ljK4E6xdlC8 CBO+apEVSIgkTU950iQceu39ruj3WgPKsn/2pMy1ieivBPxm/ByxjeRBgjXpHan4un72 ABPg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1701089143; x=1701693943; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=My7gSFRp+Y7hoOV+FBK21Q8iK89AnBNbYhuMMj6/9YA=; b=C+4GN7UC0KDdVqFSH3vu1QOUFUsP0b7rIXmhqw3gYfZhaIzW/T3R7NhsGAMkbABr3B N+0QdZkoWNIM90Gdn8B2PZHW1STVQXoVtckIsbfk4TghKnotn3uREFprO/O1zKFJh62w dOBBWvXd8Yhb7lZFq3tY9NrxpEIJo0qtQYweIvlP1vMFyg3A4AOyzbfq24c0SQqjwITt VZ+yAUTUJ0XIzA/3ozJMem4/Dk9eqzXkMAIcpxyG5ILREc3CqYK4dVu6qQ8xsxeOrl0S VdFWJ5AWCTi+UlBVA1JiZ2ZjUpPhXx3PiDGnfsD8coYgfc0J6HFGb/Q5W1tGFw+pa+jj cX4g== X-Gm-Message-State: AOJu0YzNWwmyoJPstdAUO8SYKrFTDzyK/v9MrbTHImf6vwhSOYK4897q svbPwu6iWp7qziclmSaTER++ X-Received: by 2002:ad4:4986:0:b0:66d:5d31:999e with SMTP id u6-20020ad44986000000b0066d5d31999emr12774208qvx.43.1701089143185; Mon, 27 Nov 2023 04:45:43 -0800 (PST) Received: from localhost.localdomain ([117.213.103.241]) by smtp.gmail.com with ESMTPSA id er10-20020a056214190a00b0067a204b4688sm2832231qvb.18.2023.11.27.04.45.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 27 Nov 2023 04:45:42 -0800 (PST) From: Manivannan Sadhasivam To: lpieralisi@kernel.org, kw@linux.com Cc: kishon@kernel.org, bhelgaas@google.com, mhi@lists.linux.dev, linux-arm-msm@vger.kernel.org, linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, Manivannan Sadhasivam Subject: [PATCH 0/9] bus: mhi: ep: Add async read/write support Date: Mon, 27 Nov 2023 18:15:20 +0530 Message-Id: <20231127124529.78203-1-manivannan.sadhasivam@linaro.org> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on howler.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (howler.vger.email [0.0.0.0]); Mon, 27 Nov 2023 04:46:04 -0800 (PST) X-getmail-retrieved-from-mailbox: INBOX X-GMAIL-THRID: 1783721348561430396 X-GMAIL-MSGID: 1783721348561430396 Hi, This series add async read/write support for the MHI endpoint stack by modifying the MHI ep stack and the MHI EPF (controller) driver. Currently, only sync read/write operations are supported by the stack, this resulting in poor data throughput as the transfer is halted until receiving the DMA completion. So this series adds async support such that the MHI transfers can continue without waiting for the transfer completion. And once the completion happens, host is notified by sending the transfer completion event. This series brings iperf throughput of ~4Gbps on SM8450 based dev platform, where previously 1.6Gbps was achieved with sync operation. - Mani Manivannan Sadhasivam (9): bus: mhi: ep: Pass mhi_ep_buf_info struct to read/write APIs bus: mhi: ep: Rename read_from_host() and write_to_host() APIs bus: mhi: ep: Introduce async read/write callbacks PCI: epf-mhi: Simulate async read/write using iATU PCI: epf-mhi: Add support for DMA async read/write operation PCI: epf-mhi: Enable MHI async read/write support bus: mhi: ep: Add support for async DMA write operation bus: mhi: ep: Add support for async DMA read operation bus: mhi: ep: Add checks for read/write callbacks while registering controllers drivers/bus/mhi/ep/internal.h | 1 + drivers/bus/mhi/ep/main.c | 256 +++++++++------ drivers/bus/mhi/ep/ring.c | 41 +-- drivers/pci/endpoint/functions/pci-epf-mhi.c | 314 ++++++++++++++++--- include/linux/mhi_ep.h | 33 +- 5 files changed, 485 insertions(+), 160 deletions(-) Acked-by: Bjorn Helgaas