Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp451910imm; Fri, 12 Oct 2018 00:42:11 -0700 (PDT) X-Google-Smtp-Source: ACcGV628Z4ZjhWAwtF7VbGKMi1DL87q/vU7JDLpjTOjoEPpwZ86H1WhC9tI+3eI8bNG0HBmzBE4W X-Received: by 2002:a17:902:9a8b:: with SMTP id w11-v6mr660367plp.94.1539330130943; Fri, 12 Oct 2018 00:42:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539330130; cv=none; d=google.com; s=arc-20160816; b=KzbXH6rNpn6UnmcvkWdW1t79FYZ/tXCMRClsflnlfdULvSX8m5YxEskKs5CbncYJNH KdiHY801w3ydtPEgZ/J36iCP1gksuPZmQ3LA8z2k77jx3t/lxbwhlebBI/9xDKAPVcpZ VLPlkLFm098hivphNUwJhLJtXDfqZBloM+2tnHr4E2Ejhy9OyTU9dt98rokRGM4iXbJg xnkNaCBdzqCTcG8yXvMP2gkXCzdZhlYx4PHmFALRAga9TBjAlRajZQwLNWRqymIHwb71 xhmDE5+gvaruL5qbpiNa0BQJD+BabV+tVlZXKAxBwWusZ8uBauaa+NNPgkYq9+PIDrUc XPmA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:in-reply-to :mime-version:user-agent:date:message-id:from:cc:references:to :subject; bh=TW/Qq0hNcdGY7W8YuWjXb0B4vaEsNZyQh7TmR9zi/8M=; b=bssFjDPRtcYg/wVdcBp7inA6HP6WhA/eStK27EvC6VoqKMpL0xj43GQeTT+XRsxNRC kqCx0RZIClGuf+DEkhMZDckOrN4of/a5HCpw/6KD8QXO9x/O6wkR5+Pky804+rONHwLM F/CPntJXKrvuBLwKQhptQQGQVmSoQDf61uB5rcQKsm8kGZtzWr1yPxUlU/YtFd+TNIw9 cUBI0clbrOC0Sb2xOxasG9+E3c2r0E0rABg0r/iyE52wNr+vBAsc9RYzDv8SYQGpFQOL a4OY2c0HD9C5wmHRjYnBmSqzH7jhjzkBVFNGc1kJiN0HCOj3GLPMZNoNw7KuFJ5ZKrMS DHFw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e92-v6si463466pld.358.2018.10.12.00.41.54; Fri, 12 Oct 2018 00:42:10 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727536AbeJLPMm (ORCPT + 99 others); Fri, 12 Oct 2018 11:12:42 -0400 Received: from relay1.mentorg.com ([192.94.38.131]:35792 "EHLO relay1.mentorg.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726761AbeJLPMl (ORCPT ); Fri, 12 Oct 2018 11:12:41 -0400 Received: from nat-ies.mentorg.com ([192.94.31.2] helo=SVR-IES-MBX-04.mgc.mentorg.com) by relay1.mentorg.com with esmtps (TLSv1.2:ECDHE-RSA-AES256-SHA384:256) id 1gAs4c-0002SC-3w from Vladimir_Zapolskiy@mentor.com ; Fri, 12 Oct 2018 00:41:26 -0700 Received: from [137.202.108.125] (137.202.0.90) by SVR-IES-MBX-04.mgc.mentorg.com (139.181.222.4) with Microsoft SMTP Server (TLS) id 15.0.1320.4; Fri, 12 Oct 2018 08:41:21 +0100 Subject: Re: [PATCH 4/7] mfd: ds90ux9xx: add TI DS90Ux9xx de-/serializer MFD driver To: Lee Jones , Laurent Pinchart References: <20181008211205.2900-1-vz@mleia.com> <20181008211205.2900-5-vz@mleia.com> <20181012060314.GU4939@dell> CC: Vladimir Zapolskiy , Linus Walleij , Rob Herring , Marek Vasut , Wolfram Sang , , , , From: Vladimir Zapolskiy Message-ID: <63733d2e-f95e-8894-f2b0-0b551b5cfeeb@mentor.com> Date: Fri, 12 Oct 2018 10:41:20 +0300 User-Agent: Mozilla/5.0 (X11; Linux i686; rv:45.0) Gecko/20100101 Icedove/45.2.0 MIME-Version: 1.0 In-Reply-To: <20181012060314.GU4939@dell> Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [137.202.0.90] X-ClientProxiedBy: SVR-IES-MBX-03.mgc.mentorg.com (139.181.222.3) To SVR-IES-MBX-04.mgc.mentorg.com (139.181.222.4) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Lee, On 10/12/2018 09:03 AM, Lee Jones wrote: > On Tue, 09 Oct 2018, Vladimir Zapolskiy wrote: > >> From: Vladimir Zapolskiy >> >> The change adds I2C device driver for TI DS90Ux9xx de-/serializers, >> support of subdevice controllers is done in separate drivers, because >> not all IC functionality may be needed in particular situations, and >> this can be fine grained controlled in device tree. >> >> The development of the driver was a collaborative work, the >> contribution done by Balasubramani Vivekanandan includes: >> * original implementation of the driver based on a reference driver, >> * regmap powered interrupt controller support on serializers, >> * support of implicitly or improperly specified in device tree ICs, >> * support of device properties and attributes: backward compatible >> mode, low frequency operation mode, spread spectrum clock generator. >> >> Contribution by Steve Longerbeam: >> * added ds90ux9xx_read_indirect() function, >> * moved number of links property and added ds90ux9xx_num_fpd_links(), >> * moved and updated ds90ux9xx_get_link_status() function to core driver, >> * added fpd_link_show device attribute. >> >> Sandeep Jain added support of pixel clock edge configuration. >> >> Signed-off-by: Vladimir Zapolskiy >> --- >> drivers/mfd/Kconfig | 14 + >> drivers/mfd/Makefile | 1 + >> drivers/mfd/ds90ux9xx-core.c | 879 ++++++++++++++++++++++++++++++++++ >> include/linux/mfd/ds90ux9xx.h | 42 ++ >> 4 files changed, 936 insertions(+) >> create mode 100644 drivers/mfd/ds90ux9xx-core.c >> create mode 100644 include/linux/mfd/ds90ux9xx.h >> >> diff --git a/drivers/mfd/Kconfig b/drivers/mfd/Kconfig >> index 8c5dfdce4326..a969fa123f64 100644 >> --- a/drivers/mfd/Kconfig >> +++ b/drivers/mfd/Kconfig >> @@ -1280,6 +1280,20 @@ config MFD_DM355EVM_MSP >> boards. MSP430 firmware manages resets and power sequencing, >> inputs from buttons and the IR remote, LEDs, an RTC, and more. >> >> +config MFD_DS90UX9XX >> + tristate "TI DS90Ux9xx FPD-Link de-/serializer driver" >> + depends on I2C && OF >> + select MFD_CORE >> + select REGMAP_I2C >> + help >> + Say yes here to enable support for TI DS90UX9XX de-/serializer ICs. >> + >> + This driver provides basic support for setting up the de-/serializer >> + chips. Additional functionalities like connection handling to >> + remote de-/serializers, I2C bridging, pin multiplexing, GPIO >> + controller and so on are provided by separate drivers and should >> + enabled individually. > > This is not an MFD driver. Why do you think so? The representation of the ICs into device tree format of hardware description shows that this is a truly MFD driver with multiple IP subcomponents naturally mapped into MFD cells. Basically it is possible to replace explicit of_platform_populate() by adding a "simple-mfd" compatible, if it is desired. > After a 30 second Google of what this device actually does, perhaps > drivers/media might be a better fit? > I assume it would be quite unusual to add a driver with NO media functions and controls into drivers/media. Laurent, can you please share your opinion? -- Best wishes, Vladimir