Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp2963583imw; Sun, 17 Jul 2022 22:11:26 -0700 (PDT) X-Google-Smtp-Source: AGRyM1uzVG7EkdXCuMxc1V8ZFe4V/M/YIw76EJ8/hoRWwV/U3/FaE94jN7Y+uN1wIYXdKkZE5Bxn X-Received: by 2002:a17:90a:710a:b0:1ef:991c:dc67 with SMTP id h10-20020a17090a710a00b001ef991cdc67mr31234147pjk.110.1658121085797; Sun, 17 Jul 2022 22:11:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1658121085; cv=none; d=google.com; s=arc-20160816; b=GIsdSj0NB/Oiuj3TvCpBSiS+92uK5nupSimIlsajgj2XZoY72YrQtjVm/QxE4n2YD0 qObSRnY7HuyKS3rhfpBwIiabnrPT7WoPzPvv1e3qXM7cRM5rDeNlrd9iTnLnIatXqDeq amQ/rWZQHaygPT354CZ7bCgVtLU/3Eqjw9JvauCtHjvGyCW9R+cQYPjunQkN6CKHy9SK 6bRgR3geN5DSDKM4yiPZUBJerNQ1WHRg5UJE9F73mHQz4VOuV2s3UwiyEfjSMxCwPjOl xO1zjMDc2a5aaKCk3yWNhpbJctRmUd2P9fzb5yRh920e2/eRrhKryqGuJ53GsRBSUsF0 9RgQ== 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=B8ySt9VDo72HTFN+Ek6uZZRZo9E9kZNy4yYLTwBK4JA=; b=BhfO7Xx3M/52UXfBUEmyoZOhQCDK60f8qJZhCd26UOhoyUOPB1zOaprTd+h4cUebLA 8ifG8xS+dKWFDEyKIdhTKXLea1/lVJzB8dQHjGCV080OYwnBoKdYSKXA/xDJiFapuUXC L6Bs5UlRU7mpZIFp2g2QcnqMeYIfEk2Nr1BX/l8UOuhNlFRvb+HB4ToW/Tm9go+R291c VgMw05ecn5dE3t5Oj27LXiO6sYjpyqlEgub0Znc9J1T8c2i+B3u+Bj+kP4khkm0FDOrT 37in5INV5O3hPzFPx4NWeupdr6Z9s2ZnBzQzTKnt/1kpfWV+132dV0l1AyYs5fO5Jy3e VTKw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=eQZX+2XV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id l4-20020a056a0016c400b005280e22a90csi14375697pfc.46.2022.07.17.22.11.11; Sun, 17 Jul 2022 22:11:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=eQZX+2XV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231415AbiGRFKK (ORCPT + 99 others); Mon, 18 Jul 2022 01:10:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33716 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229711AbiGRFKJ (ORCPT ); Mon, 18 Jul 2022 01:10:09 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 21EC1E0D9 for ; Sun, 17 Jul 2022 22:10:08 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id AD05E6119E for ; Mon, 18 Jul 2022 05:10:07 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 1C45FC341C0; Mon, 18 Jul 2022 05:10:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1658121007; bh=mVVWFneBEwFS1D+cOx09mi60FcdTs4CohcVB8aTEipA=; h=From:To:Cc:Subject:Date:From; b=eQZX+2XVHydJL5GxCKGi+/icT8M84zsa37GHrSnX/VvfBAajY7bUg/TIilmuLHa3W Ongo7mZqJXGjLrCKgNc+fIn28DdxunQRLvMN/ZicQhwMmjbUjqcBqRJKtTKwkt+kvf MN5e/1llvllWZ9ZKX8vpmW/TcOnApmpKwHeFQ+GTwHDjKpIDsnyf08X3Prgbl/cvAc o3AwJoTZcM/XY323CRseaWD9z4SdruR1PBCCIG+XE9kQSxtxcj4wFfynAWKSZoU+mI JxYX9aw+OM8fb21gpJmJ/82XOI56LZ8YMeE69xPSbNa8/OmdsPJe2MFHLLcGBM6xZO 73lUjszyGvX2g== From: Tzung-Bi Shih To: bleung@chromium.org, groeck@chromium.org Cc: chrome-platform@lists.linux.dev, tzungbi@kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 00/10] platform/chrome: Kunit tests and refactor for cros_ec_cmd_xfer() Date: Mon, 18 Jul 2022 05:09:04 +0000 Message-Id: <20220718050914.2267370-1-tzungbi@kernel.org> X-Mailer: git-send-email 2.37.0.170.g444d1eabd0-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The 1st patch fixes an issue that cros_kunit_ec_xfer_mock() could return garbage bytes for `msg->result` if the mock list is empty. The 2nd ~ 6th patches add Kunit tests and refactors for cros_ec_cmd_xfer(). The last 4 patches change the behavior a bit by altering return codes. Asynchronous mechanism in EC protocol: EC returns EC_RES_IN_PROGRESS if the host command needs more time to complete. It saves the result into `saved_result` once the command completed[1]. By design, AP should send another command EC_CMD_RESEND_RESPONSE for getting the result from the previous pending command[2]. The mechanism was only designed for commands that don't need responses[3]. However, the kernel code doesn't have such logic when dealing with EC_RES_IN_PROGRESS. The series doesn't fix it but leave it as is. I doubt there is no existing use case. [1]: https://crrev.com/9b80051e01872d8cae86fff999b5d31a0bea985b/common/host_command.c#113 [2]: https://crrev.com/9b80051e01872d8cae86fff999b5d31a0bea985b/common/host_command.c#748 [3]: https://crrev.com/9b80051e01872d8cae86fff999b5d31a0bea985b/common/host_command.c#126 Return value overridden in cros_ec_send_command() if asynchronous: By original intention, cros_ec_send_command() returns number of available bytes of input payload. When it falls into asynchronous path (i.e. EC_RES_IN_PROGRESS), both return value and `msg->result` will be overridden by the subsequent EC_CMD_GET_COMMS_STATUS. The series doesn't fix it but leave it as is. Tzung-Bi Shih (10): platform/chrome: cros_kunit_util: add default value for `msg->result` platform/chrome: cros_ec_proto: add "cros_ec_" prefix to send_command() platform/chrome: cros_ec_proto: add Kunit tests for cros_ec_cmd_xfer() platform/chrome: cros_ec_proto: add Kunit tests for cros_ec_send_command() platform/chrome: cros_ec_proto: separate cros_ec_xfer_command() platform/chrome: cros_ec_proto: separate cros_ec_wait_until_complete() platform/chrome: cros_ec_proto: change Kunit expectation when timed out platform/chrome: cros_ec_proto: return -EAGAIN when retries timed out platform/chrome: cros_ec_proto: add Kunit test for empty payload platform/chrome: cros_ec_proto: return -EPROTO if empty payload drivers/platform/chrome/cros_ec_proto.c | 102 +++-- drivers/platform/chrome/cros_ec_proto_test.c | 443 +++++++++++++++++++ drivers/platform/chrome/cros_kunit_util.c | 27 +- drivers/platform/chrome/cros_kunit_util.h | 5 + 4 files changed, 530 insertions(+), 47 deletions(-) Changes from v1 (https://patchwork.kernel.org/project/chrome-platform/cover/20220628024913.1755292-1-tzungbi@kernel.org/): - Drop "platform/chrome: cros_ec_proto: change Kunit expectation for EC errors" and "platform/chrome: cros_ec_proto: return standard error codes for EC errors" because they could break existing ABI. - Add "platform/chrome: cros_kunit_util: add default value for `msg->result`". -- 2.37.0.170.g444d1eabd0-goog