Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3532181pxf; Mon, 15 Mar 2021 11:39:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwwN9axXaE8rmeT39ucfSsd7EYzqKGf91J/Q3M6UzRC9tXExMZxnsPVlLeFdeoANo1jsLNk X-Received: by 2002:a17:907:75c2:: with SMTP id jl2mr25599094ejc.334.1615833561207; Mon, 15 Mar 2021 11:39:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615833561; cv=none; d=google.com; s=arc-20160816; b=QyxrrCTKbCg3ltdS4r8seh+oiALiNZts3gIKKs630XP995a9igsfSLRaQGq1B+buDT qCoRGoqrFGgm7GsFBqy8FBct8anPQt12unozBFrDgraXXFTEoIV9LJM1ddAE00TIar6N 5WMIqY5cmO9vu/jGPzYBG78muc0ehsUpplW4TwBNhDE7XezHTpaJ9cWBYqELCaGOLoTj r2zCR7iyHS2uGwHrykmpeDdqAeGuxqw4H7PUhlH0J+qc9/DLiQyYWXjR79PYP17kdLqw b8p8i4o4Eg/KrEP2b61h7Of2FeUHN7tlB03CZwpdy4QHwgam9zEyVeX0hIo0U17ApqzP 86lg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date; bh=nqD9T6nKm327OQxRMyCA9BacSWJZZiEzqcq4cx4Dxw0=; b=xG0GXDlSrB/vFmS4WbsXErxMoZ48c+wMPJS/UnG6vOQNd2ZaRatKEQxYlKvyzHK0eE NJ20f1iDfk3/6KXqbdV/hcUe7WGdcnk0yLddB0GwSAyEFYchdiJmg12KyXXmQB2sw+GY pOtkmXNtyqWZsx4emJTPN+MDT20S15YmY7mK8UPYTeTDmTa2dfLvMQG0I7WDgqDHb9Pg 7183zp9YlY72pgTVPVmo0gpkOpUtSFuhtkKNr8d98K1Y43tjaR+QJeizuhCYLNiZmuwA VNdZh9Wg5lWCm1iesl6JU7LXfFb7YyrZZM7a9tqf3RRlmP9wtbzKw27CG6o6vwrpxafc 3tBw== 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=siemens.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q16si11575999ejd.145.2021.03.15.11.38.59; Mon, 15 Mar 2021 11:39: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=siemens.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233472AbhCOQbk (ORCPT + 99 others); Mon, 15 Mar 2021 12:31:40 -0400 Received: from gecko.sbs.de ([194.138.37.40]:52057 "EHLO gecko.sbs.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229829AbhCOQbP (ORCPT ); Mon, 15 Mar 2021 12:31:15 -0400 Received: from mail2.sbs.de (mail2.sbs.de [192.129.41.66]) by gecko.sbs.de (8.15.2/8.15.2) with ESMTPS id 12FGUqrv013024 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 15 Mar 2021 17:30:52 +0100 Received: from md1za8fc.ad001.siemens.net ([139.22.41.172]) by mail2.sbs.de (8.15.2/8.15.2) with ESMTP id 12FGUpYB023993; Mon, 15 Mar 2021 17:30:51 +0100 Date: Mon, 15 Mar 2021 17:30:49 +0100 From: Henning Schild To: 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 , Hans de Goede , Pavel Machek Subject: Re: [PATCH v2 1/4] platform/x86: simatic-ipc: add main driver for Siemens devices Message-ID: <20210315173049.1d080129@md1za8fc.ad001.siemens.net> In-Reply-To: References: <20210315095710.7140-1-henning.schild@siemens.com> <20210315095710.7140-2-henning.schild@siemens.com> X-Mailer: Claws Mail 3.17.8 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am Mon, 15 Mar 2021 12:31:11 +0200 schrieb Andy Shevchenko : > On Mon, Mar 15, 2021 at 12:02 PM Henning Schild > wrote: > > > > This mainly implements detection of these devices and will allow > > secondary drivers to work on such machines. > > > > The identification is DMI-based with a vendor specific way to tell > > them apart in a reliable way. > > > > Drivers for LEDs and Watchdogs will follow to make use of that > > platform detection. > > ... > > > +static int register_platform_devices(u32 station_id) > > +{ > > + u8 ledmode = SIMATIC_IPC_DEVICE_NONE; > > + u8 wdtmode = SIMATIC_IPC_DEVICE_NONE; > > + int i; > > + > > + platform_data.devmode = SIMATIC_IPC_DEVICE_NONE; > > + > > + for (i = 0; i < ARRAY_SIZE(device_modes); i++) { > > + if (device_modes[i].station_id == station_id) { > > + ledmode = device_modes[i].led_mode; > > + wdtmode = device_modes[i].wdt_mode; > > + break; > > + } > > + } > > + > > + if (ledmode != SIMATIC_IPC_DEVICE_NONE) { > > + platform_data.devmode = ledmode; > > + ipc_led_platform_device = > > + platform_device_register_data(NULL, > > + KBUILD_MODNAME "_leds", > > PLATFORM_DEVID_NONE, > > + &platform_data, > > + sizeof(struct > > simatic_ipc_platform)); > > + if (IS_ERR(ipc_led_platform_device)) > > + return PTR_ERR(ipc_led_platform_device); > > + > > + pr_debug("device=%s created\n", > > + ipc_led_platform_device->name); > > + } > > + > > + if (wdtmode != SIMATIC_IPC_DEVICE_NONE) { > > + platform_data.devmode = wdtmode; > > + ipc_wdt_platform_device = > > + platform_device_register_data(NULL, > > + KBUILD_MODNAME "_wdt", > > PLATFORM_DEVID_NONE, > > + &platform_data, > > + sizeof(struct > > simatic_ipc_platform)); > > + if (IS_ERR(ipc_wdt_platform_device)) > > + return PTR_ERR(ipc_wdt_platform_device); > > + > > + pr_debug("device=%s created\n", > > + ipc_wdt_platform_device->name); > > + } > > + > > + if (ledmode == SIMATIC_IPC_DEVICE_NONE && > > + wdtmode == SIMATIC_IPC_DEVICE_NONE) { > > + pr_warn("unsupported IPC detected, station > > id=%08x\n", > > + station_id); > > + return -EINVAL; > > + } > > + > > + return 0; > > +} > > Why not use MFD here? > > ... > > > +/* > > + * Get membase address from PCI, used in leds and wdt modul. Here > > we read > > + * the bar0. The final address calculation is done in the > > appropriate modules > > + */ > > No blank line here. > > I would add FIXME or REVISIT here to point out that this should be > deduplicated in the future. Sure i forgot the mention that ordering problem of the two series here again specifically. Was kind of assuming yours would maybe be first and that code not being reviewed again ... The code is there to test and propose something "working" not something i expect to be merged as is. regards, Henning > > +u32 simatic_ipc_get_membase0(unsigned int p2sb) > > +{ > > + struct pci_bus *bus; > > + u32 bar0 = 0; > > + > > + /* > > + * The GPIO memory is bar0 of the hidden P2SB device. > > Unhide the device > > No, it's not a GPIO's bar. It's P2SB's one. GPIO resides in that bar > somewhere. > > > + * to have a quick look at it, before we hide it again. > > + * Also grab the pci rescan lock so that device does not > > get discovered > > + * and remapped while it is visible. > > + * This code is inspired by drivers/mfd/lpc_ich.c > > + */ > > + bus = pci_find_bus(0, 0); > > + pci_lock_rescan_remove(); > > + pci_bus_write_config_byte(bus, p2sb, 0xE1, 0x0); > > + pci_bus_read_config_dword(bus, p2sb, PCI_BASE_ADDRESS_0, > > &bar0); + > > + bar0 &= ~0xf; > > + pci_bus_write_config_byte(bus, p2sb, 0xE1, 0x1); > > + pci_unlock_rescan_remove(); > > + > > + return bar0; > > +} > > +EXPORT_SYMBOL(simatic_ipc_get_membase0); > > ... > > > +static inline u32 simatic_ipc_get_station_id(u8 *data, int max_len) > > +{ > > + u32 station_id = SIMATIC_IPC_INVALID_STATION_ID; > > + int i; > > Reversed xmas tree order, please. > > > + struct { > > + u8 type; /* type (0xff = binary) */ > > + u8 len; /* len of data entry */ > > + u8 reserved[3]; > > + u32 station_id; /* station id (LE) */ > > > + } __packed > > + *data_entry = (void *)data + sizeof(struct dmi_header); > > Can be one line. > > > + /* find 4th entry in OEM data */ > > + for (i = 0; i < 3; i++) > > 3 is magic! > > > + data_entry = (void *)((u8 *)(data_entry) + > > data_entry->len); + > > + /* decode station id */ > > + if (data_entry && (u8 *)data_entry < data + max_len && > > + data_entry->type == 0xff && data_entry->len == 9) > > + station_id = le32_to_cpu(data_entry->station_id); > > + > > + return station_id; > > +} >