Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp462226imw; Fri, 15 Jul 2022 06:42:52 -0700 (PDT) X-Google-Smtp-Source: AGRyM1uN4GSkwlqckskZfADz64QqIf1dkZYn10pHSAOFdAiYQKGd8wQX96QrIY3sc1BsEOaT4q2x X-Received: by 2002:a17:906:49:b0:6f3:bb5e:54a8 with SMTP id 9-20020a170906004900b006f3bb5e54a8mr13470449ejg.534.1657892572319; Fri, 15 Jul 2022 06:42:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657892572; cv=none; d=google.com; s=arc-20160816; b=A4Oh6bBofXXFknyPBfCSv4/MiE8GiQQVTYl4oI6XU0Mn/iG4JUMbOvT9wKMhCMAfMP AYRGcIRXUQyegk5bXfJ546jcIotkCI4W5EFy3CqH893rLBc403EjKGp2/a1gT5Vap5jm E5C26ssi0Sf02ncaBn6ERHOWQ0UihpDnvFYfbpVHC4Wp/ZBtjbcezfRFGA4LHI5N2Ice 67KOKaDBC1ysIycVN9TJvI90i929UOly1Yo8IrAfA2Fwf5HN2l7t9D1LJ7g1XIix/FNR dfin1I8oUghMv3NtqiBwlXQc1NehyOXp2A75Z/lrbren16MUCEyQSkKnMuY3yJzQcaNy phQg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:subject :from:references:cc:to:content-language:user-agent:mime-version:date :message-id:sender:dkim-signature; bh=ro8/l1mfQOif2WFPz4jXG45HCvpxO37/loKg1W9P4Pc=; b=kswhJIWGeF2HQkzNGoZzWP4J2n8iAqOOrJobWGZA56eAZwDufD+F4uZY9qBqe8gAFG KylW6/69vVj++XeJ3RF65vGV2hUn5Flo8tgloptUKKSFhie9+4yyaldwkM2mZfxOOUUB K46uDptVtpvNXI0uDVYlrQTnxN7LDVZqF43lxdEu783YObHxJj8px8rWKlnDa0pp7mN1 2VJrQ2OtZ6qmZEq0XSSFo19MlSuhTk/jEurUhYwmV6ECsQVISGCIWie0Znt8nmFe2pnC 1KY8dzlilicPcefN9LtdBpA4ihbmb5YZf+VpXnegGJLWCrtwITTwcIzkyaAWwtF9nFeY Y+0g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=U8EktRHF; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id k3-20020a1709062a4300b0072b85a5c27bsi5087689eje.871.2022.07.15.06.42.26; Fri, 15 Jul 2022 06:42:52 -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=@gmail.com header.s=20210112 header.b=U8EktRHF; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233196AbiGONeS (ORCPT + 99 others); Fri, 15 Jul 2022 09:34:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37456 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234795AbiGONeR (ORCPT ); Fri, 15 Jul 2022 09:34:17 -0400 Received: from mail-pf1-x42f.google.com (mail-pf1-x42f.google.com [IPv6:2607:f8b0:4864:20::42f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C8B627CB45; Fri, 15 Jul 2022 06:34:15 -0700 (PDT) Received: by mail-pf1-x42f.google.com with SMTP id x184so4694586pfx.2; Fri, 15 Jul 2022 06:34:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=sender:message-id:date:mime-version:user-agent:content-language:to :cc:references:from:subject:in-reply-to:content-transfer-encoding; bh=ro8/l1mfQOif2WFPz4jXG45HCvpxO37/loKg1W9P4Pc=; b=U8EktRHF0Lirp2YtqhSSsjwhmjTNFPigBZ2SA0+fXJ8MlVG8Z5ozB7+EOehhPn+Fhf GEa+bScKwOhAF3ZxX199oullW20iLsEpFZr+r+89P7Ckj8Stl05aRbpFaciDFTivQMq5 U5gY742+LT9RLFyCfHtzaJwxgNLFUDbIEM8TXI7rQsoDmrIsINvOXSf+Ya2aMwwZNCvm RGZBjO/yjC2xWKX6wPWycWKeQswZxewnSUcuDA2BHMjPVqu1JhXPv5CAu/EcYhkOccf5 +ScyIoG8MBSqFDao4rqMq1/qjJp4AKyyS83Vk4qlUnjP3S9hlsQcEvZWmCw+kpZX/LBC VZww== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:sender:message-id:date:mime-version:user-agent :content-language:to:cc:references:from:subject:in-reply-to :content-transfer-encoding; bh=ro8/l1mfQOif2WFPz4jXG45HCvpxO37/loKg1W9P4Pc=; b=A8ptWwZr/N58qy4RZlUILBTUL5qvyhaPXZ1F444WcQE3rD3Tt+3qUWl9qkFyG9DRYA y8Xa1qhVW91FdFqnGwHD0k4dPaKYkbHNNdAJ1Ke7d36/gDQLzUKSSrDciDI/H1DOqcnM xmIvtbe6YL+yvtXfCyz/CEx2iyWrx61I94euhyMFzvKLXJ+hfAjtNYzZJ1oVoioPkMPB gddUgDOB8S8r8yFbQsg1qig7z9y9xbt1P+pyB9Cp0TcPBQtdGXH8uTD4Ar+OblWMI7x+ RR+uz/HDZkqjOSAkP1sTj6reG+LLKnlbInuNDCllBVHYyS6zOPPivD5tfb8gSnNdVCW7 YKQw== X-Gm-Message-State: AJIora+/I27yUM02LDQx0X8VwQ2mRGsXmGKny5ODh9BAzEtXGyQ6b15J DkhRhajE00DzHnsWjZj18E3Y2cBbouqijQ== X-Received: by 2002:a05:6a00:815:b0:52b:295a:fad with SMTP id m21-20020a056a00081500b0052b295a0fadmr6813464pfk.62.1657892055222; Fri, 15 Jul 2022 06:34:15 -0700 (PDT) Received: from ?IPV6:2600:1700:e321:62f0:329c:23ff:fee3:9d7c? ([2600:1700:e321:62f0:329c:23ff:fee3:9d7c]) by smtp.gmail.com with ESMTPSA id q65-20020a17090a4fc700b001ef8dd1315esm5592144pjh.27.2022.07.15.06.34.12 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 15 Jul 2022 06:34:13 -0700 (PDT) Sender: Guenter Roeck Message-ID: Date: Fri, 15 Jul 2022 06:34:11 -0700 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.9.1 Content-Language: en-US To: Gene Chen , heikki.krogerus@linux.intel.com, gregkh@linuxfoundation.org, robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org Cc: linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, gene_chen@richtek.com, cy_huang@richtek.com References: <20220715100418.155011-1-gene.chen.richtek@gmail.com> <20220715100418.155011-4-gene.chen.richtek@gmail.com> From: Guenter Roeck Subject: Re: [PATCH 3/3] usb: typec: tcpci_rt1711h: Add compatible with rt1715 In-Reply-To: <20220715100418.155011-4-gene.chen.richtek@gmail.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-1.3 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,FREEMAIL_ENVFROM_END_DIGIT, FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM,HEADER_FROM_DIFFERENT_DOMAINS, NICE_REPLY_A,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS autolearn=no 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 On 7/15/22 03:04, Gene Chen wrote: > From: Gene Chen > > Add compatible with rt1715 > > Signed-off-by: Gene Chen Besides the lack of usable subject/description as mentioned by Greg, this patch is making more than one logical change. - It changes a direct register access to a regmap access - It adds mandatory regulator support (even for already supported chips) - It changes initialization for all supported chips - It implements get_cc for all chips, not just the new one, and changes some chip parameters along the line. - It adds support for the new chip So from my perspective this should be (at least) five separate patches. Implementation wise, the get_cc function is the same as the get_cc function in tcpci.c, except it adds a call to rt1711h_init_cc_params() whenever CC is read. This just seems wrong and will require a detailed explanation. Why change the chip configuration when _reading_ CC values and not in rt1711h_irq() whenever TCPC_ALERT_CC_STATUS is reported ? Guenter > --- > drivers/usb/typec/tcpm/tcpci_rt1711h.c | 168 +++++++++++++++++++++++-- > 1 file changed, 161 insertions(+), 7 deletions(-) > > diff --git a/drivers/usb/typec/tcpm/tcpci_rt1711h.c b/drivers/usb/typec/tcpm/tcpci_rt1711h.c > index b56a0880a044..1fba98e4ef03 100644 > --- a/drivers/usb/typec/tcpm/tcpci_rt1711h.c > +++ b/drivers/usb/typec/tcpm/tcpci_rt1711h.c > @@ -10,22 +10,31 @@ > #include > #include > #include > +#include > #include > #include > #include "tcpci.h" > > #define RT1711H_VID 0x29CF > #define RT1711H_PID 0x1711 > +#define RT1715_DID 0x2173 > > -#define RT1711H_RTCTRL8 0x9B > +#define RT1711H_PHYCTRL1 0x80 > +#define RT1711H_PHYCTRL2 0x81 > + > +#define RT1711H_RTCTRL4 0x93 > +/* rx threshold of rd/rp: 1b0 for level 0.4V/0.7V, 1b1 for 0.35V/0.75V */ > +#define RT1711H_BMCIO_RXDZSEL BIT(0) > > +#define RT1711H_RTCTRL8 0x9B > /* Autoidle timeout = (tout * 2 + 1) * 6.4ms */ > #define RT1711H_RTCTRL8_SET(ck300, ship_off, auto_idle, tout) \ > (((ck300) << 7) | ((ship_off) << 5) | \ > ((auto_idle) << 3) | ((tout) & 0x07)) > +#define RT1711H_AUTOIDLEEN_MASK BIT(3) > +#define RT1711H_ENEXTMSG_MASK BIT(4) > > #define RT1711H_RTCTRL11 0x9E > - > /* I2C timeout = (tout + 1) * 12.5ms */ > #define RT1711H_RTCTRL11_SET(en, tout) \ > (((en) << 7) | ((tout) & 0x0F)) > @@ -35,10 +44,17 @@ > #define RT1711H_RTCTRL15 0xA2 > #define RT1711H_RTCTRL16 0xA3 > > +#define RT1711H_RTCTRL18 0xAF > +/* 1b0 as fixed rx threshold of rd/rp 0.55V, 1b1 depends on RTCRTL4[0] */ > +#define BMCIO_RXDZEN_MASK BIT(0) > + > struct rt1711h_chip { > struct tcpci_data data; > struct tcpci *tcpci; > struct device *dev; > + struct regulator *vbus; > + bool src_en; > + u16 did; > }; > > static int rt1711h_read16(struct rt1711h_chip *chip, unsigned int reg, u16 *val) > @@ -75,8 +91,9 @@ static struct rt1711h_chip *tdata_to_rt1711h(struct tcpci_data *tdata) > > static int rt1711h_init(struct tcpci *tcpci, struct tcpci_data *tdata) > { > - int ret; > struct rt1711h_chip *chip = tdata_to_rt1711h(tdata); > + struct regmap *regmap = chip->data.regmap; > + int ret; > > /* CK 300K from 320K, shipping off, auto_idle enable, tout = 32ms */ > ret = rt1711h_write8(chip, RT1711H_RTCTRL8, > @@ -84,6 +101,14 @@ static int rt1711h_init(struct tcpci *tcpci, struct tcpci_data *tdata) > if (ret < 0) > return ret; > > + /* Enable PD30 extended message for RT1715 */ > + if (chip->did == RT1715_DID) { > + ret = regmap_update_bits(regmap, RT1711H_RTCTRL8, > + RT1711H_ENEXTMSG_MASK, 0xFF); > + if (ret < 0) > + return ret; > + } > + > /* I2C reset : (val + 1) * 12.5ms */ > ret = rt1711h_write8(chip, RT1711H_RTCTRL11, > RT1711H_RTCTRL11_SET(1, 0x0F)); > @@ -101,7 +126,37 @@ static int rt1711h_init(struct tcpci *tcpci, struct tcpci_data *tdata) > return ret; > > /* dcSRC.DRP : 33% */ > - return rt1711h_write16(chip, RT1711H_RTCTRL16, 330); > + ret = rt1711h_write16(chip, RT1711H_RTCTRL16, 330); > + if (ret < 0) > + return ret; > + > + /* Enable phy discard retry, retry count 7, rx filter deglitech 100 us */ > + ret = rt1711h_write8(chip, RT1711H_PHYCTRL1, 0xF1); > + if (ret < 0) > + return ret; > + > + /* Decrease wait time of BMC-encoded 1 bit from 2.67us to 2.55us */ > + /* wait time : (val * .4167) us */ > + return rt1711h_write8(chip, RT1711H_PHYCTRL2, 62); > +} > + > +static int rt1711h_set_vbus(struct tcpci *tcpci, struct tcpci_data *tdata, > + bool src, bool snk) > +{ > + struct rt1711h_chip *chip = tdata_to_rt1711h(tdata); > + int ret; > + > + if (chip->src_en == src) > + return 1; > + > + if (src) > + ret = regulator_enable(chip->vbus); > + else > + ret = regulator_disable(chip->vbus); > + > + if (!ret) > + chip->src_en = src; > + return ret ? ret : 1; > } > > static int rt1711h_set_vconn(struct tcpci *tcpci, struct tcpci_data *tdata, > @@ -109,8 +164,93 @@ static int rt1711h_set_vconn(struct tcpci *tcpci, struct tcpci_data *tdata, > { > struct rt1711h_chip *chip = tdata_to_rt1711h(tdata); > > - return rt1711h_write8(chip, RT1711H_RTCTRL8, > - RT1711H_RTCTRL8_SET(0, 1, !enable, 2)); > + return regmap_update_bits(chip->data.regmap, RT1711H_RTCTRL8, > + RT1711H_AUTOIDLEEN_MASK, enable ? 0 : 0xFF); > +} > + > +/* > + * Selects the CC PHY noise filter voltage level according to the current > + * CC voltage level. > + * > + * @param cc_level The CC voltage level for the port's current role > + * @return EC_SUCCESS if writes succeed; failure code otherwise > + */ > +static inline int rt1711h_init_cc_params(struct rt1711h_chip *chip, > + enum typec_cc_status cc1, enum typec_cc_status cc2) > +{ > + u32 rxdz_en = 0, rxdz_sel = 0; > + int ret; > + > + if ((cc1 >= TYPEC_CC_RP_1_5 && cc2 < TYPEC_CC_RP_DEF) || > + (cc2 >= TYPEC_CC_RP_1_5 && cc1 < TYPEC_CC_RP_DEF)) { > + if (chip->did == RT1715_DID) { > + rxdz_en = 1; > + rxdz_sel = 1; > + } else { > + rxdz_en = 1; > + rxdz_sel = 0; > + } > + } else { > + rxdz_en = 0; > + rxdz_sel = 1; > + } > + > + ret = regmap_update_bits(chip->data.regmap, RT1711H_RTCTRL18, > + BMCIO_RXDZEN_MASK, rxdz_en); > + if (ret < 0) > + return ret; > + > + return regmap_update_bits(chip->data.regmap, RT1711H_RTCTRL4, > + RT1711H_BMCIO_RXDZSEL, rxdz_en); > +} > + > +#define tcpc_presenting_rd(reg, cc) \ > + (!(TCPC_ROLE_CTRL_DRP & (reg)) && \ > + (((reg) & (TCPC_ROLE_CTRL_## cc ##_MASK << TCPC_ROLE_CTRL_## cc ##_SHIFT)) == \ > + (TCPC_ROLE_CTRL_CC_RD << TCPC_ROLE_CTRL_## cc ##_SHIFT))) > + > +static enum typec_cc_status tcpci_to_typec_cc(unsigned int cc, bool sink) > +{ > + switch (cc) { > + case 0x1: > + return sink ? TYPEC_CC_RP_DEF : TYPEC_CC_RA; > + case 0x2: > + return sink ? TYPEC_CC_RP_1_5 : TYPEC_CC_RD; > + case 0x3: > + if (sink) > + return TYPEC_CC_RP_3_0; > + fallthrough; > + case 0x0: > + default: > + return TYPEC_CC_OPEN; > + } > +} > + > +static int rt1711h_get_cc(struct tcpci *tcpci, struct tcpci_data *tdata, > + enum typec_cc_status *cc1, enum typec_cc_status *cc2) > +{ > + struct rt1711h_chip *chip = tdata_to_rt1711h(tdata); > + unsigned int reg, role_control; > + int ret; > + > + ret = regmap_read(chip->data.regmap, TCPC_ROLE_CTRL, &role_control); > + if (ret < 0) > + return ret; > + > + ret = regmap_read(chip->data.regmap, TCPC_CC_STATUS, ®); > + if (ret < 0) > + return ret; > + > + *cc1 = tcpci_to_typec_cc((reg >> TCPC_CC_STATUS_CC1_SHIFT) & > + TCPC_CC_STATUS_CC1_MASK, > + reg & TCPC_CC_STATUS_TERM || > + tcpc_presenting_rd(role_control, CC1)); > + *cc2 = tcpci_to_typec_cc((reg >> TCPC_CC_STATUS_CC2_SHIFT) & > + TCPC_CC_STATUS_CC2_MASK, > + reg & TCPC_CC_STATUS_TERM || > + tcpc_presenting_rd(role_control, CC2)); > + > + return rt1711h_init_cc_params(chip, *cc1, *cc2); > } > > static int rt1711h_start_drp_toggling(struct tcpci *tcpci, > @@ -209,7 +349,11 @@ static int rt1711h_check_revision(struct i2c_client *i2c) > dev_err(&i2c->dev, "pid is not correct, 0x%04x\n", ret); > return -ENODEV; > } > - return 0; > + ret = i2c_smbus_read_word_data(i2c, TCPC_BCD_DEV); > + if (ret < 0) > + return ret; > + dev_info(&i2c->dev, "did is 0x%04x\n", ret); > + return ret; > } > > static int rt1711h_probe(struct i2c_client *client, > @@ -228,6 +372,8 @@ static int rt1711h_probe(struct i2c_client *client, > if (!chip) > return -ENOMEM; > > + chip->did = ret; > + > chip->data.regmap = devm_regmap_init_i2c(client, > &rt1711h_regmap_config); > if (IS_ERR(chip->data.regmap)) > @@ -245,8 +391,14 @@ static int rt1711h_probe(struct i2c_client *client, > if (ret < 0) > return ret; > > + chip->vbus = devm_regulator_get(&client->dev, "vbus"); > + if (IS_ERR(chip->vbus)) > + return PTR_ERR(chip->vbus); > + > chip->data.init = rt1711h_init; > + chip->data.set_vbus = rt1711h_set_vbus; > chip->data.set_vconn = rt1711h_set_vconn; > + chip->data.get_cc = rt1711h_get_cc; > chip->data.start_drp_toggling = rt1711h_start_drp_toggling; > chip->tcpci = tcpci_register_port(chip->dev, &chip->data); > if (IS_ERR_OR_NULL(chip->tcpci)) > @@ -273,6 +425,7 @@ static int rt1711h_remove(struct i2c_client *client) > > static const struct i2c_device_id rt1711h_id[] = { > { "rt1711h", 0 }, > + { "rt1715", 0 }, > { } > }; > MODULE_DEVICE_TABLE(i2c, rt1711h_id); > @@ -280,6 +433,7 @@ MODULE_DEVICE_TABLE(i2c, rt1711h_id); > #ifdef CONFIG_OF > static const struct of_device_id rt1711h_of_match[] = { > { .compatible = "richtek,rt1711h", }, > + { .compatible = "richtek,rt1715", }, > {}, > }; > MODULE_DEVICE_TABLE(of, rt1711h_of_match);