Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756887AbdIHTB0 (ORCPT ); Fri, 8 Sep 2017 15:01:26 -0400 Received: from vps0.lunn.ch ([178.209.37.122]:33579 "EHLO vps0.lunn.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756303AbdIHTBZ (ORCPT ); Fri, 8 Sep 2017 15:01:25 -0400 Date: Fri, 8 Sep 2017 21:01:22 +0200 From: Andrew Lunn To: Tristram.Ha@microchip.com Cc: muvarov@gmail.com, pavel@ucw.cz, nathan.leigh.conrad@gmail.com, vivien.didelot@savoirfairelinux.com, f.fainelli@gmail.com, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Woojung.Huh@microchip.com Subject: Re: [PATCH RFC] Update documentation for KSZ DSA drivers so that new drivers can be added Message-ID: <20170908190122.GM25219@lunn.ch> References: <93AF473E2DA327428DE3D46B72B1E9FD41121A5B@CHN-SV-EXMX02.mchp-main.com> <20170907215417.GU11248@lunn.ch> <20170908141225.GE25219@lunn.ch> <93AF473E2DA327428DE3D46B72B1E9FD41121E68@CHN-SV-EXMX02.mchp-main.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <93AF473E2DA327428DE3D46B72B1E9FD41121E68@CHN-SV-EXMX02.mchp-main.com> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2268 Lines: 55 > > So i would suggest one driver supporting all the different devices. > > There will be 5 drivers to support these devices: > > ksz9477.c - KSZ9893/KSZ9897/KSZ9567/KSZ9566/KSZ9477 > ksz8795.c - KSZ8795/KSZ8795/KSZ8765 > ksz8895.c - KSZ8895/KSZ8864 > ksz8863.c - KSZ8863/KSZ8873 > ksz8463.c - KSZ8463 > > These chips have different SPI access mechanisms, MIB counter reading, > and register set. These can be combined into one single driver using > function pointers, at least for ksz8795/ksz8895/ksz8863/ksz8463. My > only concern is the memory footprint. The customer may not want a > big driver to cover all the switches while only one is used. If memory footprint is your problem, make it a compile time choice which devices are supported within the one driver. In practice, you will find most distributions just enable them all. > Out of topic I have a question to ask the community regarding the DSA > port creation: > > Port 1 can be specified using the reg parameter specifying 0; port 2, 1; > and so on. The KSZ8794 is a variant of KSZ8795 with port 4 disabled. > So > lan1 = 0, lan2 = 1, lan3 = 2, cpu = 4. > But our company Marketing does not want to promote that fact but treat > KSZ8794 as a distinct product. > So > lan1 = 0, lan2 = 1, lan3 = 2, cpu = 3. > Is this okay to hide this information inside the driver? This is manageable > for KSZ8794 but for KSZ8864 the first port is disabled: > lan1 = 1, lan2 = 2, lan3 = 3, cpu = 4. > > I am not sure whether DSA has or will have a way to display the port > mapping to regular users. So the port number to name is determined in the device tree. It depends on the board how the ports are named. I always suggest going by the label on the box. clearfog is a good example of this, 0 - lan5, 1 - lan4, etc. So for the KSZ8864, ensure reg = 0 causes an error. Does the hardware force which port is used for the CPU? I've boards with Marvell devices where the CPU is port 0, or port 6, or port 7. The hardware does not care. So we don't force anything. As for KSZ8794 vs KSZ8795, is there different IDs in the silicon? It is these IDs you are using, not the compatible string, to determine how the drive the silicon. You can trust the ID in the silicon. Anything else can be wrong. Andrew