diff options
18 files changed, 42 insertions, 25 deletions
| diff --git a/Documentation/devicetree/bindings/interrupt-controller/interrupts.txt b/Documentation/devicetree/bindings/interrupt-controller/interrupts.txt index ce6a1a072028..8a3c40829899 100644 --- a/Documentation/devicetree/bindings/interrupt-controller/interrupts.txt +++ b/Documentation/devicetree/bindings/interrupt-controller/interrupts.txt @@ -30,10 +30,6 @@ should only be used when a device has multiple interrupt parents.    Example:  	interrupts-extended = <&intc1 5 1>, <&intc2 1 0>; -A device node may contain either "interrupts" or "interrupts-extended", but not -both. If both properties are present, then the operating system should log an -error and use only the data in "interrupts". -  2) Interrupt controller nodes  ----------------------------- diff --git a/Documentation/devicetree/bindings/pinctrl/img,tz1090-pdc-pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/img,tz1090-pdc-pinctrl.txt index a186181c402b..51b943cc9770 100644 --- a/Documentation/devicetree/bindings/pinctrl/img,tz1090-pdc-pinctrl.txt +++ b/Documentation/devicetree/bindings/pinctrl/img,tz1090-pdc-pinctrl.txt @@ -9,7 +9,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -TZ1090-PDC's pin configuration nodes act as a container for an abitrary number +TZ1090-PDC's pin configuration nodes act as a container for an arbitrary number  of subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those pin(s)/group(s), and various pin configuration diff --git a/Documentation/devicetree/bindings/pinctrl/img,tz1090-pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/img,tz1090-pinctrl.txt index 4b27c99f7f9d..49d0e6050940 100644 --- a/Documentation/devicetree/bindings/pinctrl/img,tz1090-pinctrl.txt +++ b/Documentation/devicetree/bindings/pinctrl/img,tz1090-pinctrl.txt @@ -9,7 +9,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -TZ1090's pin configuration nodes act as a container for an abitrary number of +TZ1090's pin configuration nodes act as a container for an arbitrary number of  subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those pin(s)/group(s), and various pin configuration diff --git a/Documentation/devicetree/bindings/pinctrl/lantiq,falcon-pinumx.txt b/Documentation/devicetree/bindings/pinctrl/lantiq,falcon-pinumx.txt index daa768956069..ac4da9fe07bd 100644 --- a/Documentation/devicetree/bindings/pinctrl/lantiq,falcon-pinumx.txt +++ b/Documentation/devicetree/bindings/pinctrl/lantiq,falcon-pinumx.txt @@ -9,7 +9,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -Lantiq's pin configuration nodes act as a container for an abitrary number of +Lantiq's pin configuration nodes act as a container for an arbitrary number of  subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those group(s), and two pin configuration parameters: diff --git a/Documentation/devicetree/bindings/pinctrl/lantiq,xway-pinumx.txt b/Documentation/devicetree/bindings/pinctrl/lantiq,xway-pinumx.txt index b5469db1d7ad..e89b4677567d 100644 --- a/Documentation/devicetree/bindings/pinctrl/lantiq,xway-pinumx.txt +++ b/Documentation/devicetree/bindings/pinctrl/lantiq,xway-pinumx.txt @@ -9,7 +9,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -Lantiq's pin configuration nodes act as a container for an abitrary number of +Lantiq's pin configuration nodes act as a container for an arbitrary number of  subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those group(s), and two pin configuration parameters: diff --git a/Documentation/devicetree/bindings/pinctrl/nvidia,tegra20-pinmux.txt b/Documentation/devicetree/bindings/pinctrl/nvidia,tegra20-pinmux.txt index 61e73cde9ae9..3c8ce28baad6 100644 --- a/Documentation/devicetree/bindings/pinctrl/nvidia,tegra20-pinmux.txt +++ b/Documentation/devicetree/bindings/pinctrl/nvidia,tegra20-pinmux.txt @@ -9,7 +9,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -Tegra's pin configuration nodes act as a container for an abitrary number of +Tegra's pin configuration nodes act as a container for an arbitrary number of  subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those pin(s)/group(s), and various pin configuration diff --git a/Documentation/devicetree/bindings/pinctrl/pinctrl-sirf.txt b/Documentation/devicetree/bindings/pinctrl/pinctrl-sirf.txt index c596a6ad3285..5f55be59d914 100644 --- a/Documentation/devicetree/bindings/pinctrl/pinctrl-sirf.txt +++ b/Documentation/devicetree/bindings/pinctrl/pinctrl-sirf.txt @@ -13,7 +13,7 @@ Optional properties:  Please refer to pinctrl-bindings.txt in this directory for details of the common  pinctrl bindings used by client devices. -SiRFprimaII's pinmux nodes act as a container for an abitrary number of subnodes. +SiRFprimaII's pinmux nodes act as a container for an arbitrary number of subnodes.  Each of these subnodes represents some desired configuration for a group of pins.  Required subnode-properties: diff --git a/Documentation/devicetree/bindings/pinctrl/pinctrl_spear.txt b/Documentation/devicetree/bindings/pinctrl/pinctrl_spear.txt index b4480d5c3aca..458615596946 100644 --- a/Documentation/devicetree/bindings/pinctrl/pinctrl_spear.txt +++ b/Documentation/devicetree/bindings/pinctrl/pinctrl_spear.txt @@ -32,7 +32,7 @@ Required properties:  Please refer to pinctrl-bindings.txt in this directory for details of the common  pinctrl bindings used by client devices. -SPEAr's pinmux nodes act as a container for an abitrary number of subnodes. Each +SPEAr's pinmux nodes act as a container for an arbitrary number of subnodes. Each  of these subnodes represents muxing for a pin, a group, or a list of pins or  groups. diff --git a/Documentation/devicetree/bindings/pinctrl/qcom,apq8064-pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/qcom,apq8064-pinctrl.txt index 2fb90b37aa09..a7bde64798c7 100644 --- a/Documentation/devicetree/bindings/pinctrl/qcom,apq8064-pinctrl.txt +++ b/Documentation/devicetree/bindings/pinctrl/qcom,apq8064-pinctrl.txt @@ -18,7 +18,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -Qualcomm's pin configuration nodes act as a container for an abitrary number of +Qualcomm's pin configuration nodes act as a container for an arbitrary number of  subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those pin(s)/group(s), and various pin configuration diff --git a/Documentation/devicetree/bindings/pinctrl/qcom,apq8084-pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/qcom,apq8084-pinctrl.txt index ffafa1990a30..c4ea61ac56f2 100644 --- a/Documentation/devicetree/bindings/pinctrl/qcom,apq8084-pinctrl.txt +++ b/Documentation/devicetree/bindings/pinctrl/qcom,apq8084-pinctrl.txt @@ -47,7 +47,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -The pin configuration nodes act as a container for an abitrary number of +The pin configuration nodes act as a container for an arbitrary number of  subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those pin(s)/group(s), and various pin configuration diff --git a/Documentation/devicetree/bindings/pinctrl/qcom,ipq8064-pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/qcom,ipq8064-pinctrl.txt index e33e4dcdce79..6e88e91feb11 100644 --- a/Documentation/devicetree/bindings/pinctrl/qcom,ipq8064-pinctrl.txt +++ b/Documentation/devicetree/bindings/pinctrl/qcom,ipq8064-pinctrl.txt @@ -18,7 +18,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -Qualcomm's pin configuration nodes act as a container for an abitrary number of +Qualcomm's pin configuration nodes act as a container for an arbitrary number of  subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those pin(s)/group(s), and various pin configuration diff --git a/Documentation/devicetree/bindings/pinctrl/qcom,msm8960-pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/qcom,msm8960-pinctrl.txt index 93b7de91b9f6..eb8d8aa41f20 100644 --- a/Documentation/devicetree/bindings/pinctrl/qcom,msm8960-pinctrl.txt +++ b/Documentation/devicetree/bindings/pinctrl/qcom,msm8960-pinctrl.txt @@ -47,7 +47,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -The pin configuration nodes act as a container for an abitrary number of +The pin configuration nodes act as a container for an arbitrary number of  subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those pin(s)/group(s), and various pin configuration diff --git a/Documentation/devicetree/bindings/pinctrl/qcom,msm8974-pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/qcom,msm8974-pinctrl.txt index d2ea80dc43eb..e4d6a9d20f7d 100644 --- a/Documentation/devicetree/bindings/pinctrl/qcom,msm8974-pinctrl.txt +++ b/Documentation/devicetree/bindings/pinctrl/qcom,msm8974-pinctrl.txt @@ -18,7 +18,7 @@ Please refer to pinctrl-bindings.txt in this directory for details of the  common pinctrl bindings used by client devices, including the meaning of the  phrase "pin configuration node". -Qualcomm's pin configuration nodes act as a container for an abitrary number of +Qualcomm's pin configuration nodes act as a container for an arbitrary number of  subnodes. Each of these subnodes represents some desired configuration for a  pin, a group, or a list of pins or groups. This configuration can include the  mux function to select on those pin(s)/group(s), and various pin configuration diff --git a/Documentation/devicetree/bindings/vendor-prefixes.txt b/Documentation/devicetree/bindings/vendor-prefixes.txt index 723999d73744..a344ec2713a5 100644 --- a/Documentation/devicetree/bindings/vendor-prefixes.txt +++ b/Documentation/devicetree/bindings/vendor-prefixes.txt @@ -34,6 +34,7 @@ chipidea	Chipidea, Inc  chrp	Common Hardware Reference Platform  chunghwa	Chunghwa Picture Tubes Ltd.  cirrus	Cirrus Logic, Inc. +cnm	Chips&Media, Inc.  cortina	Cortina Systems, Inc.  crystalfontz	Crystalfontz America, Inc.  dallas	Maxim Integrated Products (formerly Dallas Semiconductor) @@ -92,6 +93,7 @@ maxim	Maxim Integrated Products  mediatek	MediaTek Inc.  micrel	Micrel Inc.  microchip	Microchip Technology Inc. +micron	Micron Technology Inc.  mitsubishi	Mitsubishi Electric Corporation  mosaixtech	Mosaix Technologies, Inc.  moxa	Moxa @@ -127,6 +129,7 @@ renesas	Renesas Electronics Corporation  ricoh	Ricoh Co. Ltd.  rockchip	Fuzhou Rockchip Electronics Co., Ltd  samsung	Samsung Semiconductor +sandisk	Sandisk Corporation  sbs	Smart Battery System  schindler	Schindler  seagate	Seagate Technology PLC @@ -138,7 +141,7 @@ silergy	Silergy Corp.  sirf	SiRF Technology, Inc.  sitronix	Sitronix Technology Corporation  smsc	Standard Microsystems Corporation -snps 	Synopsys, Inc. +snps	Synopsys, Inc.  solidrun	SolidRun  sony	Sony Corporation  spansion	Spansion Inc. diff --git a/drivers/of/address.c b/drivers/of/address.c index afdb78299f61..06af494184d6 100644 --- a/drivers/of/address.c +++ b/drivers/of/address.c @@ -450,6 +450,21 @@ static struct of_bus *of_match_bus(struct device_node *np)  	return NULL;  } +static int of_empty_ranges_quirk(void) +{ +	if (IS_ENABLED(CONFIG_PPC)) { +		/* To save cycles, we cache the result */ +		static int quirk_state = -1; + +		if (quirk_state < 0) +			quirk_state = +				of_machine_is_compatible("Power Macintosh") || +				of_machine_is_compatible("MacRISC"); +		return quirk_state; +	} +	return false; +} +  static int of_translate_one(struct device_node *parent, struct of_bus *bus,  			    struct of_bus *pbus, __be32 *addr,  			    int na, int ns, int pna, const char *rprop) @@ -475,12 +490,10 @@ static int of_translate_one(struct device_node *parent, struct of_bus *bus,  	 * This code is only enabled on powerpc. --gcl  	 */  	ranges = of_get_property(parent, rprop, &rlen); -#if !defined(CONFIG_PPC) -	if (ranges == NULL) { +	if (ranges == NULL && !of_empty_ranges_quirk()) {  		pr_err("OF: no ranges; cannot translate\n");  		return 1;  	} -#endif /* !defined(CONFIG_PPC) */  	if (ranges == NULL || rlen == 0) {  		offset = of_read_number(addr, na);  		memset(addr, 0, pna * 4); diff --git a/drivers/of/dynamic.c b/drivers/of/dynamic.c index f297891d8529..d4994177dec2 100644 --- a/drivers/of/dynamic.c +++ b/drivers/of/dynamic.c @@ -247,7 +247,7 @@ void of_node_release(struct kobject *kobj)   * @allocflags:	Allocation flags (typically pass GFP_KERNEL)   *   * Copy a property by dynamically allocating the memory of both the - * property stucture and the property name & contents. The property's + * property structure and the property name & contents. The property's   * flags have the OF_DYNAMIC bit set so that we can differentiate between   * dynamically allocated properties and not.   * Returns the newly allocated property or NULL on out of memory error. diff --git a/drivers/of/fdt.c b/drivers/of/fdt.c index d1ffca8b34ea..30e97bcc4f88 100644 --- a/drivers/of/fdt.c +++ b/drivers/of/fdt.c @@ -773,7 +773,7 @@ int __init early_init_dt_scan_chosen_serial(void)  	if (offset < 0)  		return -ENODEV; -	while (match->compatible) { +	while (match->compatible[0]) {  		unsigned long addr;  		if (fdt_node_check_compatible(fdt, offset, match->compatible)) {  			match++; diff --git a/drivers/of/selftest.c b/drivers/of/selftest.c index 11b873c54a77..e2d79afa9dc6 100644 --- a/drivers/of/selftest.c +++ b/drivers/of/selftest.c @@ -896,10 +896,14 @@ static void selftest_data_remove(void)  		return;  	} -	while (last_node_index >= 0) { +	while (last_node_index-- > 0) {  		if (nodes[last_node_index]) {  			np = of_find_node_by_path(nodes[last_node_index]->full_name); -			if (strcmp(np->full_name, "/aliases") != 0) { +			if (np == nodes[last_node_index]) { +				if (of_aliases == np) { +					of_node_put(of_aliases); +					of_aliases = NULL; +				}  				detach_node_and_children(np);  			} else {  				for_each_property_of_node(np, prop) { @@ -908,7 +912,6 @@ static void selftest_data_remove(void)  				}  			}  		} -		last_node_index--;  	}  } @@ -921,6 +924,8 @@ static int __init of_selftest(void)  	res = selftest_data_add();  	if (res)  		return res; +	if (!of_aliases) +		of_aliases = of_find_node_by_path("/aliases");  	np = of_find_node_by_path("/testcase-data/phandle-tests/consumer-a");  	if (!np) { | 
