diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2017-09-15 23:43:33 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2017-09-15 23:43:33 -0400 |
commit | 7318413077a5141a50a753b1fab687b7907eef16 (patch) | |
tree | 21a59cf856f4bb762f6d3d0635c898ca6b24cff6 /arch/mips/pci | |
parent | 8d93c7a4315711ea0f7a95ca353a89c4ed0763fb (diff) | |
parent | 35eed7cb2cf1c58a225a0140729ba787fbb06c88 (diff) |
Merge branch '4.14-features' of git://git.linux-mips.org/pub/scm/ralf/upstream-linus
Pull MIPS updates from Ralf Baechle:
"This is the main pull request for 4.14 for MIPS; below a summary of
the non-merge commits:
CM:
- Rename mips_cm_base to mips_gcr_base
- Specify register size when generating accessors
- Use BIT/GENMASK for register fields, order & drop shifts
- Add cluster & block args to mips_cm_lock_other()
CPC:
- Use common CPS accessor generation macros
- Use BIT/GENMASK for register fields, order & drop shifts
- Introduce register modify (set/clear/change) accessors
- Use change_*, set_* & clear_* where appropriate
- Add CM/CPC 3.5 register definitions
- Use GlobalNumber macros rather than magic numbers
- Have asm/mips-cps.h include CM & CPC headers
- Cluster support for topology functions
- Detect CPUs in secondary clusters
CPS:
- Read GIC_VL_IDENT directly, not via irqchip driver
DMA:
- Consolidate coherent and non-coherent dma_alloc code
- Don't use dma_cache_sync to implement fd_cacheflush
FPU emulation / FP assist code:
- Another series of 14 commits fixing corner cases such as NaN
propgagation and other special input values.
- Zero bits 32-63 of the result for a CLASS.D instruction.
- Enhanced statics via debugfs
- Do not use bools for arithmetic. GCC 7.1 moans about this.
- Correct user fault_addr type
Generic MIPS:
- Enhancement of stack backtraces
- Cleanup from non-existing options
- Handle non word sized instructions when examining frame
- Fix detection and decoding of ADDIUSP instruction
- Fix decoding of SWSP16 instruction
- Refactor handling of stack pointer in get_frame_info
- Remove unreachable code from force_fcr31_sig()
- Convert to using %pOF instead of full_name
- Remove the R6000 support.
- Move FP code from *_switch.S to *_fpu.S
- Remove unused ST_OFF from r2300_switch.S
- Allow platform to specify multiple its.S files
- Add #includes to various files to ensure code builds reliable and
without warning..
- Remove __invalidate_kernel_vmap_range
- Remove plat_timer_setup
- Declare various variables & functions static
- Abstract CPU core & VP(E) ID access through accessor functions
- Store core & VP IDs in GlobalNumber-style variable
- Unify checks for sibling CPUs
- Add CPU cluster number accessors
- Prevent direct use of generic_defconfig
- Make CONFIG_MIPS_MT_SMP default y
- Add __ioread64_copy
- Remove unnecessary inclusions of linux/irqchip/mips-gic.h
GIC:
- Introduce asm/mips-gic.h with accessor functions
- Use new GIC accessor functions in mips-gic-timer
- Remove counter access functions from irq-mips-gic.c
- Remove gic_read_local_vp_id() from irq-mips-gic.c
- Simplify shared interrupt pending/mask reads in irq-mips-gic.c
- Simplify gic_local_irq_domain_map() in irq-mips-gic.c
- Drop gic_(re)set_mask() functions in irq-mips-gic.c
- Remove gic_set_polarity(), gic_set_trigger(), gic_set_dual_edge(),
gic_map_to_pin() and gic_map_to_vpe() from irq-mips-gic.c.
- Convert remaining shared reg access, local int mask access and
remaining local reg access to new accessors
- Move GIC_LOCAL_INT_* to asm/mips-gic.h
- Remove GIC_CPU_INT* macros from irq-mips-gic.c
- Move various definitions to the driver
- Remove gic_get_usm_range()
- Remove __gic_irq_dispatch() forward declaration
- Remove gic_init()
- Use mips_gic_present() in place of gic_present and remove
gic_present
- Move gic_get_c0_*_int() to asm/mips-gic.h
- Remove linux/irqchip/mips-gic.h
- Inline __gic_init()
- Inline gic_basic_init()
- Make pcpu_masks a per-cpu variable
- Use pcpu_masks to avoid reading GIC_SH_MASK*
- Clean up mti, reserved-cpu-vectors handling
- Use cpumask_first_and() in gic_set_affinity()
- Let the core set struct irq_common_data affinity
microMIPS:
- Fix microMIPS stack unwinding on big endian systems
MIPS-GIC:
- SYNC after enabling GIC region
NUMA:
- Remove the unused parent_node() macro
R6:
- Constify r2_decoder_tables
- Add accessor & bit definitions for GlobalNumber
SMP:
- Constify smp ops
- Allow boot_secondary SMP op to return errors
VDSO:
- Drop gic_get_usm_range() usage
- Avoid use of linux/irqchip/mips-gic.h
Platform changes:
Alchemy:
- Add devboard machine type to cpuinfo
- update cpu feature overrides
- Threaded carddetect irqs for devboards
AR7:
- allow NULL clock for clk_get_rate
BCM63xx:
- Fix ENETDMA_6345_MAXBURST_REG offset
- Allow NULL clock for clk_get_rate
CI20:
- Enable GPIO and RTC drivers in defconfig
- Add ethernet and fixed-regulator nodes to DTS
Generic platform:
- Move Boston and NI 169445 FIT image source to their own files
- Include asm/bootinfo.h for plat_fdt_relocated()
- Include asm/time.h for get_c0_*_int()
- Include asm/bootinfo.h for plat_fdt_relocated()
- Include asm/time.h for get_c0_*_int()
- Allow filtering enabled boards by requirements
- Don't explicitly disable CONFIG_USB_SUPPORT
- Bump default NR_CPUS to 16
JZ4700:
- Probe the jz4740-rtc driver from devicetree
Lantiq:
- Drop check of boot select from the spi-falcon driver.
- Drop check of boot select from the lantiq-flash MTD driver.
- Access boot cause register in the watchdog driver through regmap
- Add device tree binding documentation for the watchdog driver
- Add docs for the RCU DT bindings.
- Convert the fpi bus driver to a platform_driver
- Remove ltq_reset_cause() and ltq_boot_select(
- Switch to a proper reset driver
- Switch to a new drivers/soc GPHY driver
- Add an USB PHY driver for the Lantiq SoCs using the RCU module
- Use of_platform_default_populate instead of __dt_register_buses
- Enable MFD_SYSCON to be able to use it for the RCU MFD
- Replace ltq_boot_select() with dummy implementation.
Loongson 2F:
- Allow NULL clock for clk_get_rate
Malta:
- Use new GIC accessor functions
NI 169445:
- Add support for NI 169445 board.
- Only include in 32r2el kernels
Octeon:
- Add support for watchdog of 78XX SOCs.
- Add support for watchdog of CN68XX SOCs.
- Expose support for mips32r1, mips32r2 and mips64r1
- Enable more drivers in config file
- Add support for accessing the boot vector.
- Remove old boot vector code from watchdog driver
- Define watchdog registers for 70xx, 73xx, 78xx, F75xx.
- Make CSR functions node aware.
- Allow access to CIU3 IRQ domains.
- Misc cleanups in the watchdog driver
Omega2+:
- New board, add support and defconfig
Pistachio:
- Enable Root FS on NFS in defconfig
Ralink:
- Add Mediatek MT7628A SoC
- Allow NULL clock for clk_get_rate
- Explicitly request exclusive reset control in the pci-mt7620 PCI driver.
SEAD3:
- Only include in 32 bit kernels by default
VoCore:
- Add VoCore as a vendor t0 dt-bindings
- Add defconfig file"
* '4.14-features' of git://git.linux-mips.org/pub/scm/ralf/upstream-linus: (167 commits)
MIPS: Refactor handling of stack pointer in get_frame_info
MIPS: Stacktrace: Fix microMIPS stack unwinding on big endian systems
MIPS: microMIPS: Fix decoding of swsp16 instruction
MIPS: microMIPS: Fix decoding of addiusp instruction
MIPS: microMIPS: Fix detection of addiusp instruction
MIPS: Handle non word sized instructions when examining frame
MIPS: ralink: allow NULL clock for clk_get_rate
MIPS: Loongson 2F: allow NULL clock for clk_get_rate
MIPS: BCM63XX: allow NULL clock for clk_get_rate
MIPS: AR7: allow NULL clock for clk_get_rate
MIPS: BCM63XX: fix ENETDMA_6345_MAXBURST_REG offset
mips: Save all registers when saving the frame
MIPS: Add DWARF unwinding to assembly
MIPS: Make SAVE_SOME more standard
MIPS: Fix issues in backtraces
MIPS: jz4780: DTS: Probe the jz4740-rtc driver from devicetree
MIPS: Ci20: Enable RTC driver
watchdog: octeon-wdt: Add support for 78XX SOCs.
watchdog: octeon-wdt: Add support for cn68XX SOCs.
watchdog: octeon-wdt: File cleaning.
...
Diffstat (limited to 'arch/mips/pci')
-rw-r--r-- | arch/mips/pci/pci-legacy.c | 2 | ||||
-rw-r--r-- | arch/mips/pci/pci-malta.c | 6 | ||||
-rw-r--r-- | arch/mips/pci/pci-mt7620.c | 2 | ||||
-rw-r--r-- | arch/mips/pci/pci-rt3883.c | 11 |
4 files changed, 10 insertions, 11 deletions
diff --git a/arch/mips/pci/pci-legacy.c b/arch/mips/pci/pci-legacy.c index fc7726088103..0c65c38e05d6 100644 --- a/arch/mips/pci/pci-legacy.c +++ b/arch/mips/pci/pci-legacy.c | |||
@@ -139,7 +139,7 @@ void pci_load_of_ranges(struct pci_controller *hose, struct device_node *node) | |||
139 | struct of_pci_range range; | 139 | struct of_pci_range range; |
140 | struct of_pci_range_parser parser; | 140 | struct of_pci_range_parser parser; |
141 | 141 | ||
142 | pr_info("PCI host bridge %s ranges:\n", node->full_name); | 142 | pr_info("PCI host bridge %pOF ranges:\n", node); |
143 | hose->of_node = node; | 143 | hose->of_node = node; |
144 | 144 | ||
145 | if (of_pci_range_parser_init(&parser, node)) | 145 | if (of_pci_range_parser_init(&parser, node)) |
diff --git a/arch/mips/pci/pci-malta.c b/arch/mips/pci/pci-malta.c index cfbbc3e3e914..88e625fb3a47 100644 --- a/arch/mips/pci/pci-malta.c +++ b/arch/mips/pci/pci-malta.c | |||
@@ -27,7 +27,7 @@ | |||
27 | #include <linux/init.h> | 27 | #include <linux/init.h> |
28 | 28 | ||
29 | #include <asm/gt64120.h> | 29 | #include <asm/gt64120.h> |
30 | #include <asm/mips-cm.h> | 30 | #include <asm/mips-cps.h> |
31 | #include <asm/mips-boards/generic.h> | 31 | #include <asm/mips-boards/generic.h> |
32 | #include <asm/mips-boards/bonito64.h> | 32 | #include <asm/mips-boards/bonito64.h> |
33 | #include <asm/mips-boards/msc01_pci.h> | 33 | #include <asm/mips-boards/msc01_pci.h> |
@@ -201,7 +201,7 @@ void __init mips_pcibios_init(void) | |||
201 | msc_mem_resource.start = start & mask; | 201 | msc_mem_resource.start = start & mask; |
202 | msc_mem_resource.end = (start & mask) | ~mask; | 202 | msc_mem_resource.end = (start & mask) | ~mask; |
203 | msc_controller.mem_offset = (start & mask) - (map & mask); | 203 | msc_controller.mem_offset = (start & mask) - (map & mask); |
204 | if (mips_cm_numiocu()) { | 204 | if (mips_cps_numiocu(0)) { |
205 | write_gcr_reg0_base(start); | 205 | write_gcr_reg0_base(start); |
206 | write_gcr_reg0_mask(mask | | 206 | write_gcr_reg0_mask(mask | |
207 | CM_GCR_REGn_MASK_CMTGT_IOCU0); | 207 | CM_GCR_REGn_MASK_CMTGT_IOCU0); |
@@ -213,7 +213,7 @@ void __init mips_pcibios_init(void) | |||
213 | msc_io_resource.end = (map & mask) | ~mask; | 213 | msc_io_resource.end = (map & mask) | ~mask; |
214 | msc_controller.io_offset = 0; | 214 | msc_controller.io_offset = 0; |
215 | ioport_resource.end = ~mask; | 215 | ioport_resource.end = ~mask; |
216 | if (mips_cm_numiocu()) { | 216 | if (mips_cps_numiocu(0)) { |
217 | write_gcr_reg1_base(start); | 217 | write_gcr_reg1_base(start); |
218 | write_gcr_reg1_mask(mask | | 218 | write_gcr_reg1_mask(mask | |
219 | CM_GCR_REGn_MASK_CMTGT_IOCU0); | 219 | CM_GCR_REGn_MASK_CMTGT_IOCU0); |
diff --git a/arch/mips/pci/pci-mt7620.c b/arch/mips/pci/pci-mt7620.c index 628c5132b3d8..4e633c1e7ff3 100644 --- a/arch/mips/pci/pci-mt7620.c +++ b/arch/mips/pci/pci-mt7620.c | |||
@@ -291,7 +291,7 @@ static int mt7620_pci_probe(struct platform_device *pdev) | |||
291 | IORESOURCE_MEM, 1); | 291 | IORESOURCE_MEM, 1); |
292 | u32 val = 0; | 292 | u32 val = 0; |
293 | 293 | ||
294 | rstpcie0 = devm_reset_control_get(&pdev->dev, "pcie0"); | 294 | rstpcie0 = devm_reset_control_get_exclusive(&pdev->dev, "pcie0"); |
295 | if (IS_ERR(rstpcie0)) | 295 | if (IS_ERR(rstpcie0)) |
296 | return PTR_ERR(rstpcie0); | 296 | return PTR_ERR(rstpcie0); |
297 | 297 | ||
diff --git a/arch/mips/pci/pci-rt3883.c b/arch/mips/pci/pci-rt3883.c index 3520e9b414e7..04f8ea953297 100644 --- a/arch/mips/pci/pci-rt3883.c +++ b/arch/mips/pci/pci-rt3883.c | |||
@@ -207,8 +207,7 @@ static int rt3883_pci_irq_init(struct device *dev, | |||
207 | 207 | ||
208 | irq = irq_of_parse_and_map(rpc->intc_of_node, 0); | 208 | irq = irq_of_parse_and_map(rpc->intc_of_node, 0); |
209 | if (irq == 0) { | 209 | if (irq == 0) { |
210 | dev_err(dev, "%s has no IRQ", | 210 | dev_err(dev, "%pOF has no IRQ", rpc->intc_of_node); |
211 | of_node_full_name(rpc->intc_of_node)); | ||
212 | return -EINVAL; | 211 | return -EINVAL; |
213 | } | 212 | } |
214 | 213 | ||
@@ -438,8 +437,8 @@ static int rt3883_pci_probe(struct platform_device *pdev) | |||
438 | } | 437 | } |
439 | 438 | ||
440 | if (!rpc->intc_of_node) { | 439 | if (!rpc->intc_of_node) { |
441 | dev_err(dev, "%s has no %s child node", | 440 | dev_err(dev, "%pOF has no %s child node", |
442 | of_node_full_name(rpc->intc_of_node), | 441 | rpc->intc_of_node, |
443 | "interrupt controller"); | 442 | "interrupt controller"); |
444 | return -EINVAL; | 443 | return -EINVAL; |
445 | } | 444 | } |
@@ -454,8 +453,8 @@ static int rt3883_pci_probe(struct platform_device *pdev) | |||
454 | } | 453 | } |
455 | 454 | ||
456 | if (!rpc->pci_controller.of_node) { | 455 | if (!rpc->pci_controller.of_node) { |
457 | dev_err(dev, "%s has no %s child node", | 456 | dev_err(dev, "%pOF has no %s child node", |
458 | of_node_full_name(rpc->intc_of_node), | 457 | rpc->intc_of_node, |
459 | "PCI host bridge"); | 458 | "PCI host bridge"); |
460 | err = -EINVAL; | 459 | err = -EINVAL; |
461 | goto err_put_intc_node; | 460 | goto err_put_intc_node; |