flexcan: Fix up fsl-flexcan device tree binding.

This patch cleans up the documentation of the device-tree binding for
the Flexcan devices on Freescale's PowerPC and ARM cores. Extra
properties are not used by the driver so we are removing them.

Signed-off-by: Robin Holt <holt@sgi.com>
Acked-by: Marc Kleine-Budde <mkl@pengutronix.de>,
Acked-by: Wolfgang Grandegger <wg@grandegger.com>,
Cc: U Bhaskar-B22300 <B22300@freescale.com>
Cc: Scott Wood <scottwood@freescale.com>
Cc: Grant Likely <grant.likely@secretlab.ca>
Cc: Kumar Gala <galak@kernel.crashing.org>
Cc: socketcan-core@lists.berlios.de,
Cc: netdev@vger.kernel.org,
Cc: PPC list <linuxppc-dev@lists.ozlabs.org>
Cc: devicetree-discuss@lists.ozlabs.org
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
holt@sgi.com 2011-08-16 17:32:21 +00:00 committed by David S. Miller
parent 61e271ee64
commit 243abbf2a6
3 changed files with 17 additions and 64 deletions

View File

@ -1,61 +1,22 @@
CAN Device Tree Bindings Flexcan CAN contoller on Freescale's ARM and PowerPC system-on-a-chip (SOC).
------------------------
2011 Freescale Semiconductor, Inc.
fsl,flexcan-v1.0 nodes Required properties:
-----------------------
In addition to the required compatible-, reg- and interrupt-properties, you can
also specify which clock source shall be used for the controller.
CPI Clock- Can Protocol Interface Clock - compatible : Should be "fsl,<processor>-flexcan"
This CLK_SRC bit of CTRL(control register) selects the clock source to
the CAN Protocol Interface(CPI) to be either the peripheral clock
(driven by the PLL) or the crystal oscillator clock. The selected clock
is the one fed to the prescaler to generate the Serial Clock (Sclock).
The PRESDIV field of CTRL(control register) controls a prescaler that
generates the Serial Clock (Sclock), whose period defines the
time quantum used to compose the CAN waveform.
Can Engine Clock Source An implementation should also claim any of the following compatibles
There are two sources for CAN clock that it is fully backwards compatible with:
- Platform Clock It represents the bus clock
- Oscillator Clock
Peripheral Clock (PLL) - fsl,p1010-flexcan
--------------
|
--------- -------------
| |CPI Clock | Prescaler | Sclock
| |---------------->| (1.. 256) |------------>
--------- -------------
| |
-------------- ---------------------CLK_SRC
Oscillator Clock
- fsl,flexcan-clock-source : CAN Engine Clock Source.This property selects - reg : Offset and length of the register set for this device
the peripheral clock. PLL clock is fed to the - interrupts : Interrupt tuple for this device
prescaler to generate the Serial Clock (Sclock).
Valid values are "oscillator" and "platform"
"oscillator": CAN engine clock source is oscillator clock.
"platform" The CAN engine clock source is the bus clock
(platform clock).
- fsl,flexcan-clock-divider : for the reference and system clock, an additional Example:
clock divider can be specified.
- clock-frequency: frequency required to calculate the bitrate for FlexCAN.
Note: can@1c000 {
- v1.0 of flexcan-v1.0 represent the IP block version for P1010 SOC. compatible = "fsl,p1010-flexcan";
- P1010 does not have oscillator as the Clock Source.So the default
Clock Source is platform clock.
Examples:
can0@1c000 {
compatible = "fsl,flexcan-v1.0";
reg = <0x1c000 0x1000>; reg = <0x1c000 0x1000>;
interrupts = <48 0x2>; interrupts = <48 0x2>;
interrupt-parent = <&mpic>; interrupt-parent = <&mpic>;
fsl,flexcan-clock-source = "platform";
fsl,flexcan-clock-divider = <2>;
clock-frequency = <fixed by u-boot>;
}; };

View File

@ -23,6 +23,8 @@
ethernet2 = &enet2; ethernet2 = &enet2;
pci0 = &pci0; pci0 = &pci0;
pci1 = &pci1; pci1 = &pci1;
can0 = &can0;
can1 = &can1;
}; };
memory { memory {
@ -169,14 +171,6 @@
}; };
}; };
can0@1c000 {
fsl,flexcan-clock-source = "platform";
};
can1@1d000 {
fsl,flexcan-clock-source = "platform";
};
usb@22000 { usb@22000 {
phy_type = "utmi"; phy_type = "utmi";
}; };

View File

@ -140,20 +140,18 @@
interrupt-parent = <&mpic>; interrupt-parent = <&mpic>;
}; };
can0@1c000 { can0: can@1c000 {
compatible = "fsl,flexcan-v1.0"; compatible = "fsl,p1010-flexcan";
reg = <0x1c000 0x1000>; reg = <0x1c000 0x1000>;
interrupts = <48 0x2>; interrupts = <48 0x2>;
interrupt-parent = <&mpic>; interrupt-parent = <&mpic>;
fsl,flexcan-clock-divider = <2>;
}; };
can1@1d000 { can1: can@1d000 {
compatible = "fsl,flexcan-v1.0"; compatible = "fsl,p1010-flexcan";
reg = <0x1d000 0x1000>; reg = <0x1d000 0x1000>;
interrupts = <61 0x2>; interrupts = <61 0x2>;
interrupt-parent = <&mpic>; interrupt-parent = <&mpic>;
fsl,flexcan-clock-divider = <2>;
}; };
L2: l2-cache-controller@20000 { L2: l2-cache-controller@20000 {