Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1015564ybv; Fri, 7 Feb 2020 12:43:09 -0800 (PST) X-Google-Smtp-Source: APXvYqwlav8S0ZAJVqFDT0tepinm3D9XaV2RqnR6YKcbKXgNGacZsEpY6894sNjHEFqrLJr9YDuM X-Received: by 2002:a9d:664a:: with SMTP id q10mr914371otm.298.1581108188845; Fri, 07 Feb 2020 12:43:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581108188; cv=none; d=google.com; s=arc-20160816; b=TdnaOaFNFhqwHixcobw1O37meFMEDeL2nSmlyTLj4zYg29QT5p9QNelpPodWj7Dabr jc2YqtUMl1HIz961AACX2PgQhXONGPv6EG/XSAhHhrE+oMgRBX9GbonJSO4VD7SxBAHc ZnSmqlLDhkSx3MJDCvmW6bkOQObIBIv1Vu56e9jXJkSR70agk84h3luNKbtVUT8X52VV wO5+jP67e29sx7bvLvOJPFwOdyDpYaBkRwF/WGFudsz/1N1nzYqE+wB8jGSKs8r0pVWT rOFvNLFfooo1D1Wl05Qo4ND0LrIe75Z8EH5gXlRRltjcNOuPRfNxr425+kyVS4JZat0X 5zJw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=IXG1SsgmeHKZaaUB/P+xmTOqLSj/EIyBQWrqCegBEbc=; b=HVapH6P16+qhYvKeyn0N8NCO6qO8qKFlEo3M/Q6w+RblGffHm0+KvbAGAfXDIybfX/ MDEJr/z6H1KqKuXmwOXchbAcQnON5/267YS+g5UbUSBQFL9K7U/pPT3oyJQtaUzZqUE+ 6QyJxEp5z08eZmlzIJ3NK09gNlXYzDJ7aJMZYR75fpCFIH+x3NZix1dgIDbvQIGhUERP QX9/SjNierKA4pdDXmPLQSNgbADHxDr0R8SlLNnfQvAe0ZJzbstMjucveTnH1VLkgVVE FFkggx4Ljejsw90uskYqg+HepMoteJOgltdrBnpvc6q7zaEG8Y8PVQHkolw4kPXVf6Oz ZEAA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=j3wm9jIS; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f190si4411138oig.229.2020.02.07.12.42.56; Fri, 07 Feb 2020 12:43:08 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=j3wm9jIS; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727154AbgBGUmB (ORCPT + 99 others); Fri, 7 Feb 2020 15:42:01 -0500 Received: from mail-pj1-f67.google.com ([209.85.216.67]:34884 "EHLO mail-pj1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726947AbgBGUmB (ORCPT ); Fri, 7 Feb 2020 15:42:01 -0500 Received: by mail-pj1-f67.google.com with SMTP id q39so1412945pjc.0 for ; Fri, 07 Feb 2020 12:42:01 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=IXG1SsgmeHKZaaUB/P+xmTOqLSj/EIyBQWrqCegBEbc=; b=j3wm9jISIatbqjYCuZS07BfRQUp2CI9tLsAfitjCvNycw7uq3f6MjN44Li5WpQFfqn oIpZY/4cMoMLtCLDhi6IlvfduVVV+mqOspjPIMRew7vPlbIOyjimovlc2SkLqfXM0Fz3 bPKF7nEHyjmCS5Os19CR/wqa6CtxEqjwWd320= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=IXG1SsgmeHKZaaUB/P+xmTOqLSj/EIyBQWrqCegBEbc=; b=NfM7rHuHFbszFt4hrYcmcvbQlpS75Zr4gL7shY6RiBJdqjj0T0gy2MMDI6Q6glYmg2 8qkcEWIR2nzSk73w2cwBooSaSqTayo8iXVbA91khF73DgJ4Pp6XJb96y+g6KQgvhy1Am 3Z8Jnyp+DjnBe7mT8PhOQSn1X/Sc9J2oTEc7LkZQy7FTOOnTBC1eoG8d/lsTqTDkUz4T fCvw/aORO0adOXRgFbUEI4fnFt6pL5y18b5quJcU8/VzgzhsrZGvuiFZI5IrCPtnWWme lFwGMGvH7J82aMCp/7SPcD80XMvdvdijrcSCBKhmASoIUptO0aCVz43OXMX8p4jwUeTy 9xCQ== X-Gm-Message-State: APjAAAX6O11KFvcce6DCxJg6ilTY+M4m2h5afCLON9e8xyq9fOHqpm4V M0Kll/0xT5QBaoBT5DelTpkv7Ex4lK8= X-Received: by 2002:a17:902:8f91:: with SMTP id z17mr205180plo.234.1581108120326; Fri, 07 Feb 2020 12:42:00 -0800 (PST) Received: from pmalani2.mtv.corp.google.com ([2620:15c:202:201:172e:4646:c089:ce59]) by smtp.gmail.com with ESMTPSA id 4sm4051001pfn.90.2020.02.07.12.41.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 07 Feb 2020 12:41:59 -0800 (PST) From: Prashant Malani To: linux-kernel@vger.kernel.org Cc: heikki.krogerus@intel.com, enric.balletbo@collabora.com, bleung@chromium.org, Prashant Malani , Guenter Roeck Subject: [PATCH v2 3/4] platform/chrome: typec: Get PD_CONTROL cmd version Date: Fri, 7 Feb 2020 12:37:48 -0800 Message-Id: <20200207203752.209296-4-pmalani@chromium.org> X-Mailer: git-send-email 2.25.0.341.g760bfbb309-goog In-Reply-To: <20200207203752.209296-1-pmalani@chromium.org> References: <20200207203752.209296-1-pmalani@chromium.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Query the EC to determine the version number of the PD_CONTROL command which is supported by the EC. Also store this value in the Type C data struct since it will be used to determine how to parse the response to queries for port information from the EC. Signed-off-by: Prashant Malani --- Changes in v2: - No changes. drivers/platform/chrome/cros_ec_typec.c | 34 ++++++++++++++++++++++++- 1 file changed, 33 insertions(+), 1 deletion(-) diff --git a/drivers/platform/chrome/cros_ec_typec.c b/drivers/platform/chrome/cros_ec_typec.c index 8374ccfe784f3b..df01ce86c7146c 100644 --- a/drivers/platform/chrome/cros_ec_typec.c +++ b/drivers/platform/chrome/cros_ec_typec.c @@ -21,6 +21,7 @@ struct cros_typec_data { struct device *dev; struct cros_ec_device *ec; int num_ports; + unsigned int cmd_ver; /* Array of ports, indexed by port number. */ struct typec_port *ports[EC_USB_PD_MAX_PORTS]; }; @@ -152,6 +153,31 @@ static int cros_typec_ec_command(struct cros_typec_data *typec, return ret; } +static int cros_typec_get_cmd_version(struct cros_typec_data *typec) +{ + struct ec_params_get_cmd_versions_v1 req_v1; + struct ec_response_get_cmd_versions resp; + int ret; + + /* We're interested in the PD control command version. */ + req_v1.cmd = EC_CMD_USB_PD_CONTROL; + ret = cros_typec_ec_command(typec, 1, EC_CMD_GET_CMD_VERSIONS, + &req_v1, sizeof(req_v1), &resp, + sizeof(resp)); + if (ret < 0) + return ret; + + if (resp.version_mask & EC_VER_MASK(1)) + typec->cmd_ver = 1; + else + typec->cmd_ver = 0; + + dev_dbg(typec->dev, "PD Control has version mask 0x%hhx\n", + typec->cmd_ver); + + return 0; +} + #ifdef CONFIG_ACPI static const struct acpi_device_id cros_typec_acpi_id[] = { { "GOOG0014", 0 }, @@ -182,6 +208,12 @@ static int cros_typec_probe(struct platform_device *pdev) typec->ec = dev_get_drvdata(pdev->dev.parent); platform_set_drvdata(pdev, typec); + ret = cros_typec_get_cmd_version(typec); + if (ret < 0) { + dev_err(dev, "failed to get PD command version info\n"); + return ret; + } + ret = cros_typec_ec_command(typec, 0, EC_CMD_USB_PD_PORTS, NULL, 0, &resp, sizeof(resp)); if (ret < 0) @@ -196,7 +228,7 @@ static int cros_typec_probe(struct platform_device *pdev) } ret = cros_typec_init_ports(typec); - if (!ret) + if (ret < 0) return ret; return 0; -- 2.25.0.341.g760bfbb309-goog