Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp1410308pxb; Fri, 21 Jan 2022 18:02:17 -0800 (PST) X-Google-Smtp-Source: ABdhPJx2ROQ6SHf8gm5f47iI9Q7MvchBGEo32uozDng4gnE+46yYMRZLMQSYkjNdbhCM+CqUhXT7 X-Received: by 2002:a17:902:d50d:b0:14a:4ed2:2a18 with SMTP id b13-20020a170902d50d00b0014a4ed22a18mr6575300plg.44.1642816937411; Fri, 21 Jan 2022 18:02:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642816937; cv=none; d=google.com; s=arc-20160816; b=qdwQ40JIVF55o1oDgHQvKpWv5Ux6NnG+W+wvK1KHhtO2n1DxjA1JEhLmxu2Pd/V3eG LX41T79lM0dOlquNgEY6bnDFyLbtw0ohLVbFCyhFsuqOSPbPC64wGlE1ugmL9ukg38w/ zQtYQsfMdHUNBHXTb3DnxE5cnAKDnpzLOFVMLNf6dujmm7xEjphwYdurembF+aatyYE+ 4yQpTiqjwilAjBaDPvo6BSis6DbuesoMnMtgmIpktHz/1lg/LFM75G9ek6JpAGw40BFj Dswgg2raebe3JC3lhR3BYpuEcUVg/KJnsgKZYFDd1eQNBVNQUFM0tXzFhOSdn/hFT7gE l9aQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:thread-index :content-transfer-encoding:mime-version:message-id:date:subject :in-reply-to:references:cc:to:from:dkim-signature; bh=ylGyq7sLup9Rxfkgq+dfRN9ellYolkMaBQNzruHzou0=; b=dbK92QZfiRaN9TjStmEmaafeVk7NdlAPmKts3d+OG3hFvLTgKdaolVe/QzwhWmXIMr Cf/+iuwfRJkr3jyhV1zBPyef5Of5Rz4a1x4ZSIZkte/ik5k+YGdCj1AOohcTrSC+dqYs NtkOvABwLktOMwPZYnjqJayTu5IqZG2wv/c1rIG/3dtrk6astqp15fkHuS12KJYw2IP1 /AVPrioMHIdsKVSjUpapUR05IKQcbdb6SShJkdk0+ftb170vcpXOtDspRJI3DnDm3l1U gSgnv4swQP7fek+6qicgxLAXacnJmjyBwmq3wpKbi5D9K6kSBtildYZOO4qSysz14r/Z AOWg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cirrus.com header.s=PODMain02222019 header.b=ACsTlvSN; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=cirrus.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p13si8421426pfh.140.2022.01.21.18.02.05; Fri, 21 Jan 2022 18:02:17 -0800 (PST) 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; dkim=pass header.i=@cirrus.com header.s=PODMain02222019 header.b=ACsTlvSN; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=cirrus.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1382098AbiAUQ6V (ORCPT + 99 others); Fri, 21 Jan 2022 11:58:21 -0500 Received: from mx0b-001ae601.pphosted.com ([67.231.152.168]:26652 "EHLO mx0b-001ae601.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1351590AbiAUQz2 (ORCPT ); Fri, 21 Jan 2022 11:55:28 -0500 Received: from pps.filterd (m0077474.ppops.net [127.0.0.1]) by mx0b-001ae601.pphosted.com (8.16.1.2/8.16.1.2) with ESMTP id 20L5kA6Y005173; Fri, 21 Jan 2022 10:55:12 -0600 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cirrus.com; h=from : to : cc : references : in-reply-to : subject : date : message-id : mime-version : content-type : content-transfer-encoding; s=PODMain02222019; bh=ylGyq7sLup9Rxfkgq+dfRN9ellYolkMaBQNzruHzou0=; b=ACsTlvSNjKR90Kk1SQZHW/kmzdoABEADjJu5bnXEc7B1k+9ms3TufB1J2GMYZIpe3j5x JvKVEpjZROpRbk3LOJV7xwJaqP36Kvw+9lwaW/yQSh2yVtjisyMagGF8PUujSrZVVFTY TYoqg3t4hR/LfCxP4m3kUJRaJMFlwm2BVLCXTkfz3KvTgvYye/7X2GmOYFBDXMfAJV0G vs0TyI2+zOWZaHxcBx7cdEtSvy4KYAbqc77O9Dqkip3BcOltlaKEZEvTmqk216LsGix/ VvI2U2ONS/DQpiSJpmJHXTWuuCdBZ9aUlCd9tjW2JDIq+i1ORM7zFqHPy1Ox4Zd8jWVI 8A== Received: from ediex01.ad.cirrus.com ([84.19.233.68]) by mx0b-001ae601.pphosted.com (PPS) with ESMTPS id 3dqhynrv2v-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT); Fri, 21 Jan 2022 10:55:11 -0600 Received: from EDIEX01.ad.cirrus.com (198.61.84.80) by EDIEX01.ad.cirrus.com (198.61.84.80) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.18; Fri, 21 Jan 2022 16:55:10 +0000 Received: from ediswmail.ad.cirrus.com (198.61.86.93) by EDIEX01.ad.cirrus.com (198.61.84.80) with Microsoft SMTP Server id 15.1.2375.18 via Frontend Transport; Fri, 21 Jan 2022 16:55:10 +0000 Received: from LONN2DGDQ73 (unknown [198.90.238.138]) by ediswmail.ad.cirrus.com (Postfix) with ESMTP id DF69045D; Fri, 21 Jan 2022 16:55:09 +0000 (UTC) From: Stefan Binding To: "'Rafael J. Wysocki'" CC: 'Mark Brown' , 'Len Brown' , 'Hans de Goede' , 'Mark Gross' , 'Jaroslav Kysela' , 'Takashi Iwai' , "'moderated list:SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEM...'" , 'Linux Kernel Mailing List' , 'linux-spi' , 'ACPI Devel Maling List' , 'Platform Driver' , References: <20220121143254.6432-1-sbinding@opensource.cirrus.com> <20220121143254.6432-8-sbinding@opensource.cirrus.com> In-Reply-To: Subject: RE: [PATCH v5 7/9] platform/x86: serial-multi-instantiate: Add SPI support Date: Fri, 21 Jan 2022 16:55:10 +0000 Message-ID: <019901d80ee7$a6bf2a90$f43d7fb0$@opensource.cirrus.com> MIME-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-Mailer: Microsoft Outlook 16.0 Thread-Index: AQIyNEEjz2y1WYLj0c4G0/lJ4TX/RgKST2RJAeKXLR6rlb3VEA== Content-Language: en-gb X-Proofpoint-ORIG-GUID: qRemX4_MgGf_MJQAQwN1TSlciwQ0ymrl X-Proofpoint-GUID: qRemX4_MgGf_MJQAQwN1TSlciwQ0ymrl X-Proofpoint-Spam-Reason: safe Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, > -----Original Message----- > From: Rafael J. Wysocki > Sent: 21 January 2022 15:31 > To: Stefan Binding > Cc: Mark Brown ; Rafael J . Wysocki > ; Len Brown ; Hans de Goede > ; Mark Gross ; Jaroslav > Kysela ; Takashi Iwai ; moderated > list:SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEM... devel@alsa-project.org>; Linux Kernel Mailing List kernel@vger.kernel.org>; linux-spi ; ACPI = Devel > Maling List ; Platform Driver = x86@vger.kernel.org>; patches@opensource.cirrus.com > Subject: Re: [PATCH v5 7/9] platform/x86: serial-multi-instantiate: = Add SPI > support >=20 > > diff --git a/drivers/platform/x86/Kconfig = b/drivers/platform/x86/Kconfig > > index 5b65d687f046..28f5bbf0f27a 100644 > > --- a/drivers/platform/x86/Kconfig > > +++ b/drivers/platform/x86/Kconfig > > @@ -991,12 +991,12 @@ config TOPSTAR_LAPTOP > > If you have a Topstar laptop, say Y or M here. > > > > config SERIAL_MULTI_INSTANTIATE > > - tristate "I2C multi instantiate pseudo device driver" > > - depends on I2C && ACPI > > + tristate "I2C and SPI multi instantiate pseudo device = driver" > > + depends on I2C && SPI && ACPI >=20 > Should this be (I2C || SPI) && ACPI ? We made it dependent on both I2C and SPI because of how interconnected = the serial-multi-instantiate driver is with both SPI and I2C. We felt = attempting to make the driver compatible with one without the other would end up very = complicated. > > @@ -146,7 +247,21 @@ static int smi_probe(struct platform_device = *pdev) > > > > platform_set_drvdata(pdev, smi); > > > > - return smi_i2c_probe(pdev, adev, smi, inst_array); > > + switch (node->bus_type) { > > + case SMI_I2C: > > + return smi_i2c_probe(pdev, adev, smi, = node->instances); > > + case SMI_SPI: > > + return smi_spi_probe(pdev, adev, smi, = node->instances); > > + case SMI_AUTO_DETECT: > > + if (i2c_acpi_client_count(adev) > 0) > > + return smi_i2c_probe(pdev, adev, smi, = node->instances); > > + else > > + return smi_spi_probe(pdev, adev, smi, = node->instances); > > + default: > > + break; >=20 > Why is this needed? This return code is attempting to ensure that we don=E2=80=99t try to = guess whether we expect devices to be I2C or SPI - especially with regards to existing = devices. We wanted to maintain compatibility with existing devices, which would = all be I2C. For the device for which we are adding, the same HID is used by both the = same chip for both I2C and SPI, so we also needed a way to support both. Thanks, Stefan