Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp454259pxf; Thu, 18 Mar 2021 04:46:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJydW27esUH32TxgHORkSQkma3e6/Eya9XC3zZcKmUwZKE09/WTGM/DGj8aJHS+45ZginW61 X-Received: by 2002:a17:906:94ca:: with SMTP id d10mr39839906ejy.107.1616068006141; Thu, 18 Mar 2021 04:46:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616068006; cv=none; d=google.com; s=arc-20160816; b=pex2hyCPnRHdZeh3h57xyPOGeYFrFVjICX0r49YX1rvfBfxd2KWFLhT03f1wVyTlYg N1nwkPKgzVWhlac9H/UlWubshkXFPbK9FULIIPbjDnvj7bl8Wou7GefnD9CBcTDZmf+r 0lT078cFnchVwbMgf1XZALozg7VBtGQWrxDjke619OBco4IXpEt1yNumbGiN3yabB50P RHKf9kDG9p394YuX94uRkJkNY4eZjG7EbQEn09IlDo2FkJOUnnG0EBwrD81qZa8HvuC0 k3o4PV9SAEImiLXUE8Pg3jccK3JLw31Kk9pPhvhANKKWREC1/wBvx4ZaBm1iZD6uD6/x l+5w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=rj+MpIByvkcAPNgiHQIZYz7YACaH5mhuQYo9q5r2KR0=; b=fY0sZrro7A+CGPdG00cSKKGCfxzT2Ve7wg0LuQazfKBjd/6ugrskSKcGA1zxP64gxG JNR+kVD84+acyE8ZQ6IWZ0FPQPd6Gx1vNrE7On5oxaF0JtzHMnjQItiHIYzOM94dOJrk BJbtYlSpj/xwbLT60vAaib02vkVNFcikSJd7FWUmKmie8npmczB1ufdzx4Q5fwjKfBDJ 7VfUSvAuAmdsXz2Unfb2pZV9gMwmzgycP35TycH9z8aO22DpYIH85YOPtn683bTdPDMQ vbpyFMBXnsOJKY/EBw/3oVYqhfecHFJYXIgAjN/Og1dd+uVF/b+NGVe/vbl87XMlMb65 tFoA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=hy8A3Hd6; 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=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b7si1384184edr.560.2021.03.18.04.46.22; Thu, 18 Mar 2021 04:46:46 -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; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=hy8A3Hd6; 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=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229640AbhCRLpS (ORCPT + 99 others); Thu, 18 Mar 2021 07:45:18 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:59615 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229954AbhCRLpH (ORCPT ); Thu, 18 Mar 2021 07:45:07 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1616067906; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=rj+MpIByvkcAPNgiHQIZYz7YACaH5mhuQYo9q5r2KR0=; b=hy8A3Hd62mjlIYXgnIAj9nbr1M2Vs/Jhr8PUPSlquPf+K0rdnRq6+2D0K1tqfAmBUKNrP9 A7qi3wat9lva0Y+6kU8nOM8NKECUOVpgPQFo9VtxvAY8IzJvMGzL0PoyqWuZacbpvdwZNu 6uLm4Ke+O5NzIDoSVushzPmp6GPTfM0= Received: from mail-ej1-f72.google.com (mail-ej1-f72.google.com [209.85.218.72]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-226-1PZpkhbBMNCeBIU3s6694g-1; Thu, 18 Mar 2021 07:45:04 -0400 X-MC-Unique: 1PZpkhbBMNCeBIU3s6694g-1 Received: by mail-ej1-f72.google.com with SMTP id v27so11751439ejq.0 for ; Thu, 18 Mar 2021 04:45:03 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=rj+MpIByvkcAPNgiHQIZYz7YACaH5mhuQYo9q5r2KR0=; b=TolHDGmxak2BWnzEM6vWG9iXNwwBH5Svac0vvVCAbm/dsJZyxu7oUziB4Lu/GIrBeP eoEvP3h6xDlSHoHdT3ukUTTPVo5jH5t1OB+3wakZR2ToqINbmbVh3DIg4fQl1QmxROZn NPbuUhBjeKXdtDkeaR0Gl/e42OIAPbfwUeMhrDR+H47MPjIDFRn3ROEo9bL3jkY9qLo4 S+SmhrwvkkmM8f91iM+8yuQFLII7nCfoYETiaulpaanYxWOcr+5WKEQIE2X4ajAjjIs+ 5Cb3UbwoFgtZnaYuCVUtnZLOHmxdSdnHljLLvev2QJIXW1W+qyj28xeiHFVT8sr4MPuG zj0g== X-Gm-Message-State: AOAM5319Bq/sFVxhsMGqY8SDsRZ4Nx5P/e+lnQuIay7aVmHInRPeQIfx zG6fViZdQfyCVCl59XjZLpKfNIRid4D+m21rxo2ugGiEKaL3qitTIRXWe58XR7S6fXHF8gGptZA ESdIR/XsM7YesV5Ydls9Cp88g X-Received: by 2002:a17:906:53d7:: with SMTP id p23mr40817609ejo.140.1616067903025; Thu, 18 Mar 2021 04:45:03 -0700 (PDT) X-Received: by 2002:a17:906:53d7:: with SMTP id p23mr40817596ejo.140.1616067902848; Thu, 18 Mar 2021 04:45:02 -0700 (PDT) Received: from x1.localdomain (2001-1c00-0c1e-bf00-1054-9d19-e0f0-8214.cable.dynamic.v6.ziggo.nl. [2001:1c00:c1e:bf00:1054:9d19:e0f0:8214]) by smtp.gmail.com with ESMTPSA id a12sm1830424edx.91.2021.03.18.04.45.02 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 18 Mar 2021 04:45:02 -0700 (PDT) Subject: Re: [PATCH v2 1/4] platform/x86: simatic-ipc: add main driver for Siemens devices To: "Enrico Weigelt, metux IT consult" , Henning Schild , Andy Shevchenko Cc: Linux Kernel Mailing List , Linux LED Subsystem , Platform Driver , linux-watchdog@vger.kernel.org, Srikanth Krishnakar , Jan Kiszka , Gerd Haeussler , Guenter Roeck , Wim Van Sebroeck , Mark Gross , Pavel Machek References: <20210315095710.7140-1-henning.schild@siemens.com> <20210315095710.7140-2-henning.schild@siemens.com> <20210317201311.70528fd4@md1za8fc.ad001.siemens.net> <92080a68-9029-3103-9240-65c92d17bf16@redhat.com> <6c7d165d-1332-2039-0af3-9875b482894b@metux.net> From: Hans de Goede Message-ID: <420f0e08-bec8-f85a-d9af-b9900072df66@redhat.com> Date: Thu, 18 Mar 2021 12:45:01 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.7.0 MIME-Version: 1.0 In-Reply-To: <6c7d165d-1332-2039-0af3-9875b482894b@metux.net> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 3/18/21 12:30 PM, Enrico Weigelt, metux IT consult wrote: > On 17.03.21 21:03, Hans de Goede wrote: > > Hi, > >>> It just identifies the box and tells subsequent drivers which one it >>> is, which watchdog and LED path to take. Moving the knowledge of which >>> box has which LED/watchdog into the respective drivers seems to be the >>> better way to go. >>> >>> So we would end up with a LED and a watchdog driver both >>> MODULE_ALIAS("dmi:*:svnSIEMENSAG:*"); > > Uh, isn't that a bit too broad ? This basically implies that Siemens > will never produce boards with different configurations. There is a further check done in probe() based on some Siemens specific DMI table entries. >>> and doing the identification with the inline dmi from that header, >>> doing p2sb with the support to come ... possibly a "//TODO\ninline" in >>> the meantime. >>> >>> So no "main platform" driver anymore, but still central platform >>> headers. >>> >>> Not sure how this sounds, but i think making that change should be >>> possible. And that is what i will try and go for in v3. >> >> Dropping the main drivers/platform/x86 driver sounds good to me, >> I was already wondering a bit about its function since it just >> instantiates devs to which the other ones bind to then instantiate >> more devs (in the LED case). > > hmm, IMHO that depends on whether the individual sub-devices can be > more generic than just that specific machine. (@Hanning: could you > tell us more about that ?). > > Another question is how they're actually probed .. only dmi or maybe > also pci dev ? (i've seen some refs to pci stuff in the led driver, but > missed the other code thats called here). > > IMHO, if the whole thing lives on some PCI device (which can be probed > via pci ID), and that device has the knowledge, where the LED registers > actually are (eg. based on device ID, pci mmio mapping, ...) then there > should be some parent driver that instantiates the led devices (and > possibly other board specific stuff). That would be a clear separation, > modularization. In that case, maybe this LED driver could even be > replaced by some really generic "register-based-LED" driver, which just > needs to be fed with some parameters like register ranges, bitmasks, etc. > > OTOH, if everything can be derived entirely from DMI match, w/o things > like pci mappings involved (IOW: behaves like directly wired to the > cpu's mem/io bus, no other "intelligent" bus involved), and it's all > really board specific logic (no generic led or gpio controllers > involved), then it might be better to have entirely separate drivers. FWIW I'm fine with either solution, and if we go the "parent driver" route I'm happy to have that driver sit in drivers/platform/x86 (once all the discussions surrounding this are resolved). My reply was because I noticed that the Led driver seemed to sort of also act as a parent driver (last time I looked) and instantiated a bunch of stuff, so then we have 2 parent(ish) drivers. If things stay that way then having 2 levels of parent drivers seems a bit too much to me, esp. if it can all be done cleanly in e.g. the LED driver. But as said I'm fine either way as long as the code is reasonably clean and dealing with this sort of platform specific warts happens a lot in drivers/platform/x86 . Regards, Hans