Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp5420469rwr; Mon, 24 Apr 2023 04:05:46 -0700 (PDT) X-Google-Smtp-Source: AKy350aSqwxe83f0GkLWkltyIO1oduGZSy7VDW8end3wG48XL5rkt4koYPSHcVYMZOq8waCHEXo5 X-Received: by 2002:a17:90b:4a07:b0:23d:4229:f7cf with SMTP id kk7-20020a17090b4a0700b0023d4229f7cfmr13418446pjb.41.1682334346169; Mon, 24 Apr 2023 04:05:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1682334346; cv=none; d=google.com; s=arc-20160816; b=pCMxQnve8WyixhzzlmewtKLAAa1sym0q4ciEuETlcLDgP0v4EU0ggb/HRwA6iwrh4d BZiZhCFd/wKbpoKt7DQHv1UjbuyLkOBMYy8JMkg4WY9x/S3aAFyYUcDSIj43i72hDcpl n/spCF4droxOFPEAy/Iqz35179QFFyMYh7vgnMwmAQZLd/fGFl54gq2DmxM9RVy0/LrQ 3f+eMWAtj6dKR1e9vd6IGUoNvCJ38IgrTavRVAH1qc0dc0Z3jPWdKfY3OulRfAJDajFG iwAUSm/zsyiYh6ckVsFDVq8UQlEAPbp9oCahqGHkKa/xv55hfQfm9ISEn9s3aj9+cqlU m0JA== 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:references :to:from:content-language:subject:user-agent:mime-version:date :message-id:dkim-signature; bh=m9VVsVkoNQe3FV95JtBFOJyvk7GxFioVrIy0ckbpl6E=; b=jP1PI1oHw2kPC4ZkOxZ8jC5IJU/AkWNQvxiFiC4eUjDZhgViGOq+YCMlF0+WsD/3L7 5bqLTBESsr4NCbNoBSldGAoNftwlbI1bGZiDZLGh3JeeLZgWvLGP9HNhnjJWwbNMzYyn AUD8QX1IM2GGyreRNHg4EEIUijv6viBNhGBeQs/Y25MJy/KyMp5DDESNqpZ23w+nPk2k 8lnFBa9qUkjD+fFtC8GqmLcAwSMs0ep3tuEU/CpUakXYr6dESHBds90JFIH+oaDojICW npvT6fUJ7GGfLHJV1yjibCYjBaiUChwQkTp6ddFbURkGlDwO45hh+ex/acNT7icW27Xr s9Tg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=X5QTDvZO; 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 h9-20020a17090acf0900b002467e72af54si10920900pju.43.2023.04.24.04.05.27; Mon, 24 Apr 2023 04:05:46 -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 (test mode) header.i=@ideasonboard.com header.s=mail header.b=X5QTDvZO; 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 S231488AbjDXLBZ (ORCPT + 99 others); Mon, 24 Apr 2023 07:01:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45050 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231249AbjDXLBY (ORCPT ); Mon, 24 Apr 2023 07:01:24 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 60AC835A9; Mon, 24 Apr 2023 04:01:20 -0700 (PDT) Received: from [192.168.88.20] (91-154-35-171.elisa-laajakaista.fi [91.154.35.171]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 1932B9DE; Mon, 24 Apr 2023 13:01:07 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1682334068; bh=Dge9CpuzYlCmb1f/D/o+Nlsl3C6MkM0cjJz+ChrCDMc=; h=Date:Subject:From:To:References:In-Reply-To:From; b=X5QTDvZOlH5vPmODcDAabiMKFORtv3QBwylKImoQNN9/s0dxL0aEcYleIqs8EVZQN xz+aTvM7iIt6231Rx+G/9l1e0H8tYxfgiwlmne5gJEn0pLDDjr8re4ZYQ0vpPE3nDC rVjB6pVV8L80s4/U+LvDcVwmfT+WNe4KzP86VUmQ= Message-ID: <30e4656f-63d9-a79c-c1d9-23d0a16cf184@ideasonboard.com> Date: Mon, 24 Apr 2023 14:01:13 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.10.0 Subject: Re: [PATCH v11 1/7] i2c: add I2C Address Translator (ATR) support Content-Language: en-US From: Tomi Valkeinen To: Wolfram Sang , linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-i2c@vger.kernel.org, Rob Herring , Krzysztof Kozlowski , Luca Ceresoli , Andy Shevchenko , Matti Vaittinen , Laurent Pinchart , Mauro Carvalho Chehab , Peter Rosin , Liam Girdwood , Mark Brown , Sakari Ailus , Michael Tretter , Hans Verkuil , Mike Pagano , =?UTF-8?Q?Krzysztof_Ha=c5=82asa?= , Marek Vasut , Satish Nagireddy , Luca Ceresoli , Andy Shevchenko References: <20230421101833.345984-1-tomi.valkeinen@ideasonboard.com> <20230421101833.345984-2-tomi.valkeinen@ideasonboard.com> In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-3.3 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,SPF_HELO_PASS, SPF_PASS,T_SCC_BODY_TEXT_LINE 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 On 24/04/2023 13:51, Tomi Valkeinen wrote: > On 24/04/2023 13:31, Wolfram Sang wrote: >> On Fri, Apr 21, 2023 at 01:18:27PM +0300, Tomi Valkeinen wrote: >>> From: Luca Ceresoli >>> >>> An ATR is a device that looks similar to an i2c-mux: it has an I2C >>> slave "upstream" port and N master "downstream" ports, and forwards >>> transactions from upstream to the appropriate downstream port. But it >>> is different in that the forwarded transaction has a different slave >>> address. The address used on the upstream bus is called the "alias" >>> and is (potentially) different from the physical slave address of the >>> downstream chip. >>> >>> Add a helper file (just like i2c-mux.c for a mux or switch) to allow >>> implementing ATR features in a device driver. The helper takes care or >>> adapter creation/destruction and translates addresses at each >>> transaction. >>> >>> Signed-off-by: Luca Ceresoli >>> Signed-off-by: Tomi Valkeinen >>> Reviewed-by: Andy Shevchenko >> >> This looks good to me. Dunno if the DT folks want the binding as a >> seperate patch, but this is good to go as far as I am concerned. > > Ah, right. I'll resend with the DT bindings separate. Also, looks like I forgot to remove the namespaces for export symbols. Tomi