Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp1129431pxf; Thu, 18 Mar 2021 22:36:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx0mYwou7F0u++uKmQT+fNHQFvjOcZ+tt/CH6ETIQZfmEowl8nHwHOKBOt1ttWSNTPWlKvz X-Received: by 2002:a17:906:2b46:: with SMTP id b6mr2308186ejg.521.1616132181699; Thu, 18 Mar 2021 22:36:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616132181; cv=none; d=google.com; s=arc-20160816; b=UXqoDLtNXtgE5PpC5hzI0rqz+PLf6a7kOyuh6idBKzlDTa/gAr0ZMMYwVcTdG2kIpS lU+BobdXiU0t+vJSB/YY5DnyTsPQ4/vH41onebzLQNmTjkDrA8XT8Y31QULYN2ovdwcW harzxLM4ivU+BAYjjtEAqIH0+RvE0WpactAA3cgzRs0ezMNiQnCupXPsc2r4HFjb0jDW ZDLOyNxAe/j+rqVVpz+OZd3DO1jf22z54Jk8KUYiWrNR2oRSnRDBgMLOkjReMJQQm8/d SLW/9wgn7hGWAZTjSJW6rM7lHho0M63Fud242mkmaPYb0+epHm79KdNpoqQCQkh7Jm18 WuGg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:ironport-sdr:ironport-sdr; bh=GONCv5AqRfJgOsNmlUXHaejR7L4bhJlES4/OXnnSCw8=; b=CmmAdyeOsekB/md6/o5ksBvgRcpKB3CbVRRJNi7lkM3Zj8BoQU6Shxfipg+4bd5rtX 7YA2/qCdZmyzJSODhnVWLsT1nNvCXpe3Xvm0X6meXOQ2AKDTxvRrHGCrTwc+UDkS9xJs K02WNXBI8YliqJHn6MT5dEGhpTRwOer6/HoFjqcjGOgqq3QWE2A5Y842JTuNwE78eFPu U8WtkwNOO9B3urDhwNnvTpIG+Rs5Q3A2rtP8J9VFHnN6+V9x3VEkpf/jaZnu5HwARqih cpN9Rjba4qjFtaxT63i5aYJZ50yiDP3DlkcGW2G2wMtBu5COXSTqzHlSSZIPX+N7XbKm y02g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y7si3141124ejd.159.2021.03.18.22.35.58; Thu, 18 Mar 2021 22:36:21 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233882AbhCSFcE (ORCPT + 99 others); Fri, 19 Mar 2021 01:32:04 -0400 Received: from mga02.intel.com ([134.134.136.20]:29790 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233867AbhCSFbl (ORCPT ); Fri, 19 Mar 2021 01:31:41 -0400 IronPort-SDR: HyuVtMwvHoohml2lVzRDMHcFeJn3rLSOoGUEN9KmeB078GELf9VpULK2Pt+PDo7tU0rpF+fx32 8mwXNvHNkgbw== X-IronPort-AV: E=McAfee;i="6000,8403,9927"; a="176963987" X-IronPort-AV: E=Sophos;i="5.81,261,1610438400"; d="scan'208";a="176963987" Received: from orsmga005.jf.intel.com ([10.7.209.41]) by orsmga101.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 18 Mar 2021 22:31:40 -0700 IronPort-SDR: dXFG2bQZSZ9t+2XLd6fS7oSesFueKUxpbXN/Rrt78E48wlYb5JrAd6ivXaPu6U1r8KwIENuh6x +w9BxKUimsLA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.81,261,1610438400"; d="scan'208";a="591744750" Received: from unknown (HELO [10.239.154.55]) ([10.239.154.55]) by orsmga005.jf.intel.com with ESMTP; 18 Mar 2021 22:31:34 -0700 Subject: Re: [PATCH v8] i2c: virtio: add a virtio i2c frontend driver To: Viresh Kumar , Arnd Bergmann Cc: "Enrico Weigelt, metux IT consult" , Linux I2C , virtualization@lists.linux-foundation.org, Linux Kernel Mailing List , "Michael S. Tsirkin" , Wolfram Sang , Jason Wang , Wolfram Sang , Andy Shevchenko , conghui.chen@intel.com, kblaiech@mellanox.com, jarkko.nikula@linux.intel.com, Sergey Semin , Mike Rapoport , loic.poulain@linaro.org, Tali Perry , =?UTF-8?Q?Uwe_Kleine-K=c3=b6nig?= , Bjorn Andersson , yu1.wang@intel.com, shuo.a.liu@intel.com, Stefan Hajnoczi , Paolo Bonzini References: <20210316074409.2afwsaeqxuwvj7bd@vireshk-i7> <0dfff1ac-50bb-b5bc-72ea-880fd52ed60d@metux.net> <20210319035435.a4reve77hnvjdzwk@vireshk-i7> From: Jie Deng Message-ID: Date: Fri, 19 Mar 2021 13:31:34 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Firefox/78.0 Thunderbird/78.7.0 MIME-Version: 1.0 In-Reply-To: <20210319035435.a4reve77hnvjdzwk@vireshk-i7> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2021/3/19 11:54, Viresh Kumar wrote: > On 18-03-21, 15:52, Arnd Bergmann wrote: >> Allowing multiple virtio-i2c controllers in one system, and multiple i2c >> devices attached to each controller is clearly something that has to work. > Good. > >> I don't actually see a limitation though. Viresh, what is the problem >> you see for having multiple controllers? > I thought this would be a problem in that case as we are using the global > virtio_adapter here. > > + vi->adap = &virtio_adapter; > + i2c_set_adapdata(vi->adap, vi); > > Multiple calls to probe() will end up updating the same pointer inside adap. > > + vi->adap->dev.parent = &vdev->dev; > > Same here, overwrite. > > + /* Setup ACPI node for controlled devices which will be probed through ACPI */ > + ACPI_COMPANION_SET(&vi->adap->dev, ACPI_COMPANION(pdev)); > + vi->adap->timeout = HZ / 10; > > These may be fine, but still not ideal I believe. > > + ret = i2c_add_adapter(vi->adap); > i > This should be a problem as well, we must be adding this to some sort of list, > doing some RPM stuff, etc ? > > Jie, the solution is to allocate memory for adap at runtime in probe and remove > the virtio_adapter structure completely. If you want to support that. Then I think we don't need to change the following at all. > +    .algo = &virtio_algorithm, > + > +        return ret; > + > +    vi->adap = virtio_adapter; This is strange, why are you allocating memory for adapter twice ? Once for virtio_adapter and once for vi->adap ? Either fill the fields directly for v->adap here and remove virtio_adapter or make vi->adap a pointer.