On Thu, Jul 25, 2019 at 8:24 AM Akinobu Mita <akinobu.mita@xxxxxxxxx> wrote: > > 2019年7月23日(火) 7:16 Rob Herring <robh@xxxxxxxxxx>: > > > > On Mon, Jul 01, 2019 at 11:12:32PM +0900, Akinobu Mita wrote: > > > Add thermal binding documentation for NVMe temperature sensor. > > > > > > Cc: Rob Herring <robh@xxxxxxxxxx> > > > Cc: Zhang Rui <rui.zhang@xxxxxxxxx> > > > Cc: Eduardo Valentin <edubezval@xxxxxxxxx> > > > Cc: Daniel Lezcano <daniel.lezcano@xxxxxxxxxx> > > > Cc: Keith Busch <kbusch@xxxxxxxxxx> > > > Cc: Jens Axboe <axboe@xxxxxx> > > > Cc: Christoph Hellwig <hch@xxxxxx> > > > Cc: Sagi Grimberg <sagi@xxxxxxxxxxx> > > > Cc: Minwoo Im <minwoo.im.dev@xxxxxxxxx> > > > Cc: Kenneth Heitke <kenneth.heitke@xxxxxxxxx> > > > Cc: Chaitanya Kulkarni <Chaitanya.Kulkarni@xxxxxxx> > > > Signed-off-by: Akinobu Mita <akinobu.mita@xxxxxxxxx> > > > --- > > > * v5 > > > - New patch > > > > > > Documentation/devicetree/bindings/thermal/nvme.txt | 56 ++++++++++++++++++++++ > > > 1 file changed, 56 insertions(+) > > > create mode 100644 Documentation/devicetree/bindings/thermal/nvme.txt > > > > > > diff --git a/Documentation/devicetree/bindings/thermal/nvme.txt b/Documentation/devicetree/bindings/thermal/nvme.txt > > > new file mode 100644 > > > index 0000000..60b90de > > > --- /dev/null > > > +++ b/Documentation/devicetree/bindings/thermal/nvme.txt > > > @@ -0,0 +1,56 @@ > > > +Binding for NVMe temperature sensor > > > + > > > +An NVMe controller reports up to nine temperature values in the SMART / Health > > > +log. > > > + > > > +Required properties: > > > +- reg: A five-cell address encoded as (phys.hi phys.mid phys.lo size.hi > > > + size.lo). phys.hi should contain the device's BDF (Bus/Device/Function) > > > + as 0b00000000 bbbbbbbb dddddfff 00000000. The other cells should be zero. > > > + See also Documentation/devicetree/bindings/pci/pci.txt > > > + > > > +- #thermal-sensor-cells: Must be 1. See ./thermal.txt for a description. > > > + In the thermal-sensors property, the sensor ID 0 for composite temperature, > > > + 1 through 8 for NVMe temperature sensor N. > > > + > > > +Example: > > > + > > > +&pcie0 { > > > + ... > > > + nvme: nvme@0,0 { > > > + reg = <0x0000 0 0 0 0>; > > > + #address-cells = <3>; > > > + #size-cells = <2>; > > > + > > > + nvmetemp: nvmetemp { > > > + reg = <0x0000 0 0 0 0>; /* DEVFN = 0x00 (0:0) */ > > > > I'm not sure this is really valid PCI addressing as the parent has the > > same address. > > > > > + #thermal-sensor-cells = <1>; > > > > Can't you just put this in the parent? Is this really a separate > > addressable device from the parent? > > How about this? > > &pcie0 { > ... > pci-bridge@0 { > reg = <0x00000 0 0 0 0>; > #address-cells = <3>; > #size-cells = <2>; > > nvme: nvme@0,0 { > reg = <0x10000 0 0 0 0>; > #thermal-sensor-cells = <1>; > }; > }; > }; > > and > > &thermal_zones { > ... > thermal-sensors = <&nvme 0>; > }; > > I tested this with the RockPro64 and edited > arch/arm64/boot/dts/rockchip/rk3399-rockpro64.dts. > > $ lspci > 00:00.0 PCI bridge: Fuzhou Rockchip Electronics Co., Ltd Device 0100 > 01:00.0 Non-Volatile memory controller: Micron/Crucial Technology > Device 2263 (rev 03) > > $ lspci -tv > -[0000:00]---00.0-[01]----00.0 Micron/Crucial Technology Device 2263 Looks better to me. Rob