RE: [patch v2 1/1 - resend] Documentation: dt-bindings: Add Device Tree bindings for Mellanox programming devices

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




> -----Original Message-----
> From: Rob Herring [mailto:robh@xxxxxxxxxx]
> Sent: Thursday, August 10, 2017 8:40 PM
> To: Vadim Pasternak <vadimp@xxxxxxxxxxxx>
> Cc: devicetree@xxxxxxxxxxxxxxx; lee.jones@xxxxxxxxxx; pavel@xxxxxx;
> j.anaszewski@xxxxxxxxxxx; rpurdie@xxxxxxxxx; linux-
> leds@xxxxxxxxxxxxxxx; jiri@xxxxxxxxxxx; jacek.anaszewski@xxxxxxxxx
> Subject: Re: [patch v2 1/1 - resend] Documentation: dt-bindings: Add Device
> Tree bindings for Mellanox programming devices
> 
> On Thu, Aug 03, 2017 at 12:04:19PM +0000, Vadim Pasternak wrote:
> > The mlxreg a multifunction device driver handling LEDs, events,
> > exposing through sysfs reset signal, and reset causes info. These
> > components share a common register space.
> 
> "dt-bindings: mfd: ..." for the subject please.
> 

Hi Rob,
Thank you for review.

OK, will change the subject.

> >
> > Signed-off-by: Vadim Pasternak <vadimp@xxxxxxxxxxxx>
> > ---
> >  .../devicetree/bindings/mfd/mellanox,mlxreg-core   | 346
> +++++++++++++++++++++
> >  1 file changed, 346 insertions(+)
> >  create mode 100644
> > Documentation/devicetree/bindings/mfd/mellanox,mlxreg-core
> >
> > diff --git
> > a/Documentation/devicetree/bindings/mfd/mellanox,mlxreg-core
> > b/Documentation/devicetree/bindings/mfd/mellanox,mlxreg-core
> > new file mode 100644
> > index 0000000..a90933e
> > --- /dev/null
> > +++ b/Documentation/devicetree/bindings/mfd/mellanox,mlxreg-core
> > @@ -0,0 +1,346 @@
> > +Mellanox programmable device control.
> > +-------------------------------------
> > +This binding defines the device control interface over I2C bus for
> > +Mellanox BMC based switches.
> > +
> > +Required properties:
> > +- compatible = "mellanox,mlxreg-i2c",
> > +	       "mellanox,mlxreg-i2c-16",
> > +	       "mellanox,mlxreg-core";
> 
> This is all one compatible entry? Why 3 compatibles?

It could be
	"mellanox,mlxreg-i2c" or
	"mellanox,mlxreg-i2c-16"

Is it not correct syntax?

And I think I'll drop "mellanox,mlxreg-core".

> 
> > +- #address-cells : must be 1;
> > +- #size-cells : must be 0;
> > +- reg : I2C address;
> > +
> > +Optional properties:
> > +- interrupt-parent : phandle of parent interrupt controller;
> > +- interrupts : interrupt line;
> > +- deferred - I2C deferred bus phandle;
> > +	     For example, for the case when device attached to I2C bus
> number 4
> > +	     performs dynamic attachment of device to bus 12 upon some
> event.
> > +	     Due to this reason bus 4 is enforced to be activated after bus
> > +12;
> 
> I don't understand...

For example I have CPLD device on i2c4, which handles the signals for ASIC device. I can connect this device to the bus at initialization time in case it's ready, or upon receiving the relevant signal when it's getting ready:
&i2c4 {
	mlxcpld-swb-ctrl@72 {
		#address-cells = <1>;
		#size-cells = <0>;
		interrupt-parent = <&gpio>;
		interrupts = <ASPEED_GPIO(S, 1) 2>;
		compatible = "mellanox,mlxreg-i2c";
		reg = <0x72>;
		deferred = <&i2c12>;
		cell = <0x40>;
		mask = <0x01>;

		asic {
			aggr_mask = <0x01>;
			regs = <0x50>;
			masks = <0x03>;
			phandles = <&asic_thermal>;
		};
....
};

The ASIC device is connected to i2c12:
&i2c12 {
	status = "okay";
	#address-cells = <1>;
	#size-cells = <0>;

	asic_thermal: mlxsw_minimal@48 {
		compatible = "mlxsw_minimal";
		reg = <0x48>;
		status = "disabled";
		cooling-phandle = <&cooling>;

		trips {
			/* trip type, temp in mcelsius, temp min, temp max */
			trip@0 {
				trip = <0 75000 0 0>;
			};
			trip@1 {
				trip = <2 85000 1 5>;
			};
			trip@3 {
				trip = <2 105000 5 5>;
			};
		};
	};
};

So, in this case i2c4 should be activated after i2c12 and for this reason device mlxcpld-swb-ctrl@72 is deferred on activation of i2c12.

> 
> > +- cell - top aggregation register offset;
> > +- mask - top aggregation register mask;
> > +- psu - power supply unit nodes:
> 
> This section is "Optional Properties" and this is a sub-node. Each subnode
> should have its own section.

ACK

> 
> > +	- aggr_mask - effective bit in aggregation mask;
> 
> Don't use '_' in node or property names.

ACK

> 
> > +	- reg - register offset for all group members;
> > +	- mask - register mask;
> > +	- phandles - list of relevant device nodes;
> 
> Other than reg, I don't understand what any of these are.
> 
> From what I can tell you are describing things down to register bit level which
> generally is too much detail in DT. How many variations of h/w do you have?
> Do you really need to be able to define any possible combination or have
> some finite set?

We have about 10 different 1U systems with different numbers of FANs, with replicable or
non-replaceable PSU. I am also planning to support director systems, which has different
configurations - different number of leaf and  spine cards and power supply and FAN units.
This is the wide range of system from smallest with 16x100G ports with biggest with 800x200G ports.
I really need flexibility in device description.

In field mask I assign the affective mask for dynamic devices, f.e. example for system with 4 FANs
mask will be 0x0f, with 6 0x3f and for director system it can be located in several registers with masks
0xff.

Handles have the next purpose. For example for fan nodes I provide the list of EEPROM devices'
handles, which should be connected/disconnected on insert/remove:

		fan {
			aggr_mask = <0x40>;
			reg = <0x88>;
			mask = <0x0f>;
			phandles = <&fan1_eeprom &fan2_eeprom &fan3_eeprom
				    &fan4_eeprom>;
		};

And this EEPROM devices are connected to i2c switch device like below:
&i2c6 {
	...
	i2cswitch@71 {
		compatible = "nxp,pca9548";
		#address-cells = <1>;
		#size-cells = <0>;
		reg = <0x71>;

                i2c@0 {
                        #address-cells = <1>;
                        #size-cells = <0>;
                        reg = <0>;

                        fan1_eeprom: at24c04@50 {
                                compatible = "atmel,24c32";
                                reg = <0x50>;
				status = "disabled";
                        };
                };

                i2c@1 {
                        #address-cells = <1>;
                        #size-cells = <0>;
                        reg = <1>;

                        fan2_eeprom: at24c04@50 {
                                compatible = "atmel,24c32";
                                reg = <0x50>;
				status = "disabled";
                        };
                };

                i2c@2 {
                        #address-cells = <1>;
                        #size-cells = <0>;
                        reg = <2>;

                        fan3_eeprom: at24c04@50 {
                                compatible = "atmel,24c32";
                                reg = <0x50>;
				status = "disabled";
                        };
                };

                i2c@3 {
                        #address-cells = <1>;
                        #size-cells = <0>;
                        reg = <3>;

                        fan4_eeprom: at24c04@50 {
                                compatible = "atmel,24c32";
                                reg = <0x50>;
				status = "disabled";
                        };
                };

	};
};

> 
> Rob




[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux