mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-18 22:14:16 +00:00 
			
		
		
		
	Merge tag 'kvm-s390-master-5.14-1' of git://git.kernel.org/pub/scm/linux/kernel/git/kvms390/linux into HEAD
KVM: selftests: Fixes - provide memory model for IBM z196 and zEC12 - do not require 64GB of memory
This commit is contained in:
		
						commit
						f3cf800778
					
				
					 719 changed files with 6706 additions and 3284 deletions
				
			
		|  | @ -109,8 +109,8 @@ ForEachMacros: | |||
|   - 'css_for_each_child' | ||||
|   - 'css_for_each_descendant_post' | ||||
|   - 'css_for_each_descendant_pre' | ||||
|   - 'cxl_for_each_cmd' | ||||
|   - 'device_for_each_child_node' | ||||
|   - 'displayid_iter_for_each' | ||||
|   - 'dma_fence_chain_for_each' | ||||
|   - 'do_for_each_ftrace_op' | ||||
|   - 'drm_atomic_crtc_for_each_plane' | ||||
|  | @ -136,6 +136,7 @@ ForEachMacros: | |||
|   - 'drm_mm_for_each_node_in_range' | ||||
|   - 'drm_mm_for_each_node_safe' | ||||
|   - 'flow_action_for_each' | ||||
|   - 'for_each_acpi_dev_match' | ||||
|   - 'for_each_active_dev_scope' | ||||
|   - 'for_each_active_drhd_unit' | ||||
|   - 'for_each_active_iommu' | ||||
|  | @ -171,7 +172,6 @@ ForEachMacros: | |||
|   - 'for_each_dapm_widgets' | ||||
|   - 'for_each_dev_addr' | ||||
|   - 'for_each_dev_scope' | ||||
|   - 'for_each_displayid_db' | ||||
|   - 'for_each_dma_cap_mask' | ||||
|   - 'for_each_dpcm_be' | ||||
|   - 'for_each_dpcm_be_rollback' | ||||
|  | @ -179,6 +179,7 @@ ForEachMacros: | |||
|   - 'for_each_dpcm_fe' | ||||
|   - 'for_each_drhd_unit' | ||||
|   - 'for_each_dss_dev' | ||||
|   - 'for_each_dtpm_table' | ||||
|   - 'for_each_efi_memory_desc' | ||||
|   - 'for_each_efi_memory_desc_in_map' | ||||
|   - 'for_each_element' | ||||
|  | @ -215,6 +216,7 @@ ForEachMacros: | |||
|   - 'for_each_migratetype_order' | ||||
|   - 'for_each_msi_entry' | ||||
|   - 'for_each_msi_entry_safe' | ||||
|   - 'for_each_msi_vector' | ||||
|   - 'for_each_net' | ||||
|   - 'for_each_net_continue_reverse' | ||||
|   - 'for_each_netdev' | ||||
|  | @ -270,6 +272,12 @@ ForEachMacros: | |||
|   - 'for_each_prime_number_from' | ||||
|   - 'for_each_process' | ||||
|   - 'for_each_process_thread' | ||||
|   - 'for_each_prop_codec_conf' | ||||
|   - 'for_each_prop_dai_codec' | ||||
|   - 'for_each_prop_dai_cpu' | ||||
|   - 'for_each_prop_dlc_codecs' | ||||
|   - 'for_each_prop_dlc_cpus' | ||||
|   - 'for_each_prop_dlc_platforms' | ||||
|   - 'for_each_property_of_node' | ||||
|   - 'for_each_registered_fb' | ||||
|   - 'for_each_requested_gpio' | ||||
|  | @ -430,6 +438,7 @@ ForEachMacros: | |||
|   - 'queue_for_each_hw_ctx' | ||||
|   - 'radix_tree_for_each_slot' | ||||
|   - 'radix_tree_for_each_tagged' | ||||
|   - 'rb_for_each' | ||||
|   - 'rbtree_postorder_for_each_entry_safe' | ||||
|   - 'rdma_for_each_block' | ||||
|   - 'rdma_for_each_port' | ||||
|  |  | |||
							
								
								
									
										3
									
								
								.mailmap
									
										
									
									
									
								
							
							
						
						
									
										3
									
								
								.mailmap
									
										
									
									
									
								
							|  | @ -243,6 +243,9 @@ Maxime Ripard <mripard@kernel.org> <maxime.ripard@free-electrons.com> | |||
| Mayuresh Janorkar <mayur@ti.com> | ||||
| Michael Buesch <m@bues.ch> | ||||
| Michel Dänzer <michel@tungstengraphics.com> | ||||
| Michel Lespinasse <michel@lespinasse.org> | ||||
| Michel Lespinasse <michel@lespinasse.org> <walken@google.com> | ||||
| Michel Lespinasse <michel@lespinasse.org> <walken@zoy.org> | ||||
| Miguel Ojeda <ojeda@kernel.org> <miguel.ojeda.sandonis@gmail.com> | ||||
| Mike Rapoport <rppt@kernel.org> <mike@compulab.co.il> | ||||
| Mike Rapoport <rppt@kernel.org> <mike.rapoport@gmail.com> | ||||
|  |  | |||
|  | @ -149,6 +149,17 @@ properties: | |||
|     maxItems: 6 | ||||
|     $ref: /schemas/types.yaml#/definitions/uint32-array | ||||
| 
 | ||||
|   sink-vdos-v1: | ||||
|     description: An array of u32 with each entry, a Vendor Defined Message Object (VDO), | ||||
|       providing additional information corresponding to the product, the detailed bit | ||||
|       definitions and the order of each VDO can be found in | ||||
|       "USB Power Delivery Specification Revision 2.0, Version 1.3" chapter 6.4.4.3.1 Discover | ||||
|       Identity. User can specify the VDO array via VDO_IDH/_CERT/_PRODUCT/_CABLE/_AMA defined in | ||||
|       dt-bindings/usb/pd.h. | ||||
|     minItems: 3 | ||||
|     maxItems: 6 | ||||
|     $ref: /schemas/types.yaml#/definitions/uint32-array | ||||
| 
 | ||||
|   op-sink-microwatt: | ||||
|     description: Sink required operating power in microwatt, if source can't | ||||
|       offer the power, Capability Mismatch is set. Required for power sink and | ||||
|  | @ -207,6 +218,10 @@ properties: | |||
|       SNK_READY for non-pd link. | ||||
|     type: boolean | ||||
| 
 | ||||
| dependencies: | ||||
|   sink-vdos-v1: [ 'sink-vdos' ] | ||||
|   sink-vdos: [ 'sink-vdos-v1' ] | ||||
| 
 | ||||
| required: | ||||
|   - compatible | ||||
| 
 | ||||
|  |  | |||
|  | @ -49,7 +49,7 @@ examples: | |||
|         #size-cells = <0>; | ||||
| 
 | ||||
|         adc@48 { | ||||
|             comatible = "ti,ads7828"; | ||||
|             compatible = "ti,ads7828"; | ||||
|             reg = <0x48>; | ||||
|             vref-supply = <&vref>; | ||||
|             ti,differential-input; | ||||
|  |  | |||
|  | @ -67,9 +67,7 @@ properties: | |||
|     maxItems: 1 | ||||
| 
 | ||||
|   clock-names: | ||||
|     maxItems: 1 | ||||
|     items: | ||||
|       - const: fck | ||||
|     const: fck | ||||
| 
 | ||||
|   resets: | ||||
|     maxItems: 1 | ||||
|  |  | |||
|  | @ -57,7 +57,7 @@ patternProperties: | |||
|           rate | ||||
| 
 | ||||
|       sound-dai: | ||||
|         $ref: /schemas/types.yaml#/definitions/phandle | ||||
|         $ref: /schemas/types.yaml#/definitions/phandle-array | ||||
|         description: phandle of the CPU DAI | ||||
| 
 | ||||
|     patternProperties: | ||||
|  | @ -71,7 +71,7 @@ patternProperties: | |||
| 
 | ||||
|         properties: | ||||
|           sound-dai: | ||||
|             $ref: /schemas/types.yaml#/definitions/phandle | ||||
|             $ref: /schemas/types.yaml#/definitions/phandle-array | ||||
|             description: phandle of the codec DAI | ||||
| 
 | ||||
|         required: | ||||
|  |  | |||
|  | @ -58,6 +58,6 @@ RISC-V Linux Kernel SV39 | |||
|                                                               | | ||||
|   ____________________________________________________________|____________________________________________________________ | ||||
|                     |            |                  |         | | ||||
|    ffffffff00000000 |   -4    GB | ffffffff7fffffff |    2 GB | modules | ||||
|    ffffffff80000000 |   -2    GB | ffffffffffffffff |    2 GB | kernel, BPF | ||||
|    ffffffff00000000 |   -4    GB | ffffffff7fffffff |    2 GB | modules, BPF | ||||
|    ffffffff80000000 |   -2    GB | ffffffffffffffff |    2 GB | kernel | ||||
|   __________________|____________|__________________|_________|____________________________________________________________ | ||||
|  |  | |||
|  | @ -181,7 +181,7 @@ SLUB Debug output | |||
| Here is a sample of slub debug output:: | ||||
| 
 | ||||
|  ==================================================================== | ||||
|  BUG kmalloc-8: Redzone overwritten | ||||
|  BUG kmalloc-8: Right Redzone overwritten | ||||
|  -------------------------------------------------------------------- | ||||
| 
 | ||||
|  INFO: 0xc90f6d28-0xc90f6d2b. First byte 0x00 instead of 0xcc | ||||
|  | @ -189,10 +189,10 @@ Here is a sample of slub debug output:: | |||
|  INFO: Object 0xc90f6d20 @offset=3360 fp=0xc90f6d58 | ||||
|  INFO: Allocated in get_modalias+0x61/0xf5 age=53 cpu=1 pid=554 | ||||
| 
 | ||||
|  Bytes b4 0xc90f6d10:  00 00 00 00 00 00 00 00 5a 5a 5a 5a 5a 5a 5a 5a ........ZZZZZZZZ | ||||
|    Object 0xc90f6d20:  31 30 31 39 2e 30 30 35                         1019.005 | ||||
|   Redzone 0xc90f6d28:  00 cc cc cc                                     . | ||||
|   Padding 0xc90f6d50:  5a 5a 5a 5a 5a 5a 5a 5a                         ZZZZZZZZ | ||||
|  Bytes b4 (0xc90f6d10): 00 00 00 00 00 00 00 00 5a 5a 5a 5a 5a 5a 5a 5a ........ZZZZZZZZ | ||||
|  Object   (0xc90f6d20): 31 30 31 39 2e 30 30 35                         1019.005 | ||||
|  Redzone  (0xc90f6d28): 00 cc cc cc                                     . | ||||
|  Padding  (0xc90f6d50): 5a 5a 5a 5a 5a 5a 5a 5a                         ZZZZZZZZ | ||||
| 
 | ||||
|    [<c010523d>] dump_trace+0x63/0x1eb | ||||
|    [<c01053df>] show_trace_log_lvl+0x1a/0x2f | ||||
|  |  | |||
							
								
								
									
										22
									
								
								MAINTAINERS
									
										
									
									
									
								
							
							
						
						
									
										22
									
								
								MAINTAINERS
									
										
									
									
									
								
							|  | @ -3877,6 +3877,7 @@ L:	linux-btrfs@vger.kernel.org | |||
| S:	Maintained | ||||
| W:	http://btrfs.wiki.kernel.org/ | ||||
| Q:	http://patchwork.kernel.org/project/linux-btrfs/list/ | ||||
| C:	irc://irc.libera.chat/btrfs | ||||
| T:	git git://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux.git | ||||
| F:	Documentation/filesystems/btrfs.rst | ||||
| F:	fs/btrfs/ | ||||
|  | @ -6945,6 +6946,7 @@ F:	net/core/failover.c | |||
| FANOTIFY | ||||
| M:	Jan Kara <jack@suse.cz> | ||||
| R:	Amir Goldstein <amir73il@gmail.com> | ||||
| R:	Matthew Bobrowski <repnop@google.com> | ||||
| L:	linux-fsdevel@vger.kernel.org | ||||
| S:	Maintained | ||||
| F:	fs/notify/fanotify/ | ||||
|  | @ -12905,7 +12907,7 @@ F:	net/ipv4/nexthop.c | |||
| 
 | ||||
| NFC SUBSYSTEM | ||||
| M:	Krzysztof Kozlowski <krzysztof.kozlowski@canonical.com> | ||||
| L:	linux-nfc@lists.01.org (moderated for non-subscribers) | ||||
| L:	linux-nfc@lists.01.org (subscribers-only) | ||||
| L:	netdev@vger.kernel.org | ||||
| S:	Maintained | ||||
| F:	Documentation/devicetree/bindings/net/nfc/ | ||||
|  | @ -12918,7 +12920,7 @@ F:	net/nfc/ | |||
| NFC VIRTUAL NCI DEVICE DRIVER | ||||
| M:	Bongsu Jeon <bongsu.jeon@samsung.com> | ||||
| L:	netdev@vger.kernel.org | ||||
| L:	linux-nfc@lists.01.org (moderated for non-subscribers) | ||||
| L:	linux-nfc@lists.01.org (subscribers-only) | ||||
| S:	Supported | ||||
| F:	drivers/nfc/virtual_ncidev.c | ||||
| F:	tools/testing/selftests/nci/ | ||||
|  | @ -13216,7 +13218,7 @@ F:	sound/soc/codecs/tfa9879* | |||
| 
 | ||||
| NXP-NCI NFC DRIVER | ||||
| R:	Charles Gorand <charles.gorand@effinnov.com> | ||||
| L:	linux-nfc@lists.01.org (moderated for non-subscribers) | ||||
| L:	linux-nfc@lists.01.org (subscribers-only) | ||||
| S:	Supported | ||||
| F:	drivers/nfc/nxp-nci | ||||
| 
 | ||||
|  | @ -14119,6 +14121,7 @@ F:	drivers/pci/controller/pci-v3-semi.c | |||
| PCI ENDPOINT SUBSYSTEM | ||||
| M:	Kishon Vijay Abraham I <kishon@ti.com> | ||||
| M:	Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> | ||||
| R:	Krzysztof Wilczyński <kw@linux.com> | ||||
| L:	linux-pci@vger.kernel.org | ||||
| S:	Supported | ||||
| F:	Documentation/PCI/endpoint/* | ||||
|  | @ -14167,6 +14170,7 @@ F:	drivers/pci/controller/pci-xgene-msi.c | |||
| PCI NATIVE HOST BRIDGE AND ENDPOINT DRIVERS | ||||
| M:	Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> | ||||
| R:	Rob Herring <robh@kernel.org> | ||||
| R:	Krzysztof Wilczyński <kw@linux.com> | ||||
| L:	linux-pci@vger.kernel.org | ||||
| S:	Supported | ||||
| Q:	http://patchwork.ozlabs.org/project/linux-pci/list/ | ||||
|  | @ -16145,7 +16149,7 @@ F:	include/media/drv-intf/s3c_camif.h | |||
| SAMSUNG S3FWRN5 NFC DRIVER | ||||
| M:	Krzysztof Kozlowski <krzysztof.kozlowski@canonical.com> | ||||
| M:	Krzysztof Opasiak <k.opasiak@samsung.com> | ||||
| L:	linux-nfc@lists.01.org (moderated for non-subscribers) | ||||
| L:	linux-nfc@lists.01.org (subscribers-only) | ||||
| S:	Maintained | ||||
| F:	Documentation/devicetree/bindings/net/nfc/samsung,s3fwrn5.yaml | ||||
| F:	drivers/nfc/s3fwrn5 | ||||
|  | @ -16558,6 +16562,7 @@ F:	drivers/misc/sgi-xp/ | |||
| 
 | ||||
| SHARED MEMORY COMMUNICATIONS (SMC) SOCKETS | ||||
| M:	Karsten Graul <kgraul@linux.ibm.com> | ||||
| M:	Guvenc Gulce <guvenc@linux.ibm.com> | ||||
| L:	linux-s390@vger.kernel.org | ||||
| S:	Supported | ||||
| W:	http://www.ibm.com/developerworks/linux/linux390/ | ||||
|  | @ -18335,7 +18340,7 @@ F:	sound/soc/codecs/tas571x* | |||
| TI TRF7970A NFC DRIVER | ||||
| M:	Mark Greer <mgreer@animalcreek.com> | ||||
| L:	linux-wireless@vger.kernel.org | ||||
| L:	linux-nfc@lists.01.org (moderated for non-subscribers) | ||||
| L:	linux-nfc@lists.01.org (subscribers-only) | ||||
| S:	Supported | ||||
| F:	Documentation/devicetree/bindings/net/nfc/trf7970a.txt | ||||
| F:	drivers/nfc/trf7970a.c | ||||
|  | @ -18871,6 +18876,13 @@ S:	Maintained | |||
| F:	drivers/usb/host/isp116x* | ||||
| F:	include/linux/usb/isp116x.h | ||||
| 
 | ||||
| USB ISP1760 DRIVER | ||||
| M:	Rui Miguel Silva <rui.silva@linaro.org> | ||||
| L:	linux-usb@vger.kernel.org | ||||
| S:	Maintained | ||||
| F:	drivers/usb/isp1760/* | ||||
| F:	Documentation/devicetree/bindings/usb/nxp,isp1760.yaml | ||||
| 
 | ||||
| USB LAN78XX ETHERNET DRIVER | ||||
| M:	Woojung Huh <woojung.huh@microchip.com> | ||||
| M:	UNGLinuxDriver@microchip.com | ||||
|  |  | |||
							
								
								
									
										9
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										9
									
								
								Makefile
									
										
									
									
									
								
							|  | @ -2,8 +2,8 @@ | |||
| VERSION = 5 | ||||
| PATCHLEVEL = 13 | ||||
| SUBLEVEL = 0 | ||||
| EXTRAVERSION = -rc4 | ||||
| NAME = Frozen Wasteland | ||||
| EXTRAVERSION = -rc7 | ||||
| NAME = Opossums on Parade | ||||
| 
 | ||||
| # *DOCUMENTATION*
 | ||||
| # To see a list of typical targets execute "make help"
 | ||||
|  | @ -929,11 +929,14 @@ CC_FLAGS_LTO	+= -fvisibility=hidden | |||
| # Limit inlining across translation units to reduce binary size
 | ||||
| KBUILD_LDFLAGS += -mllvm -import-instr-limit=5 | ||||
| 
 | ||||
| # Check for frame size exceeding threshold during prolog/epilog insertion.
 | ||||
| # Check for frame size exceeding threshold during prolog/epilog insertion
 | ||||
| # when using lld < 13.0.0.
 | ||||
| ifneq ($(CONFIG_FRAME_WARN),0) | ||||
| ifeq ($(shell test $(CONFIG_LLD_VERSION) -lt 130000; echo $$?),0) | ||||
| KBUILD_LDFLAGS	+= -plugin-opt=-warn-stack-size=$(CONFIG_FRAME_WARN) | ||||
| endif | ||||
| endif | ||||
| endif | ||||
| 
 | ||||
| ifdef CONFIG_LTO | ||||
| KBUILD_CFLAGS	+= -fno-lto $(CC_FLAGS_LTO) | ||||
|  |  | |||
|  | @ -18,6 +18,7 @@ | |||
|  */ | ||||
| struct sigcontext { | ||||
| 	struct user_regs_struct regs; | ||||
| 	struct user_regs_arcv2 v2abi; | ||||
| }; | ||||
| 
 | ||||
| #endif /* _ASM_ARC_SIGCONTEXT_H */ | ||||
|  |  | |||
|  | @ -61,6 +61,41 @@ struct rt_sigframe { | |||
| 	unsigned int sigret_magic; | ||||
| }; | ||||
| 
 | ||||
| static int save_arcv2_regs(struct sigcontext *mctx, struct pt_regs *regs) | ||||
| { | ||||
| 	int err = 0; | ||||
| #ifndef CONFIG_ISA_ARCOMPACT | ||||
| 	struct user_regs_arcv2 v2abi; | ||||
| 
 | ||||
| 	v2abi.r30 = regs->r30; | ||||
| #ifdef CONFIG_ARC_HAS_ACCL_REGS | ||||
| 	v2abi.r58 = regs->r58; | ||||
| 	v2abi.r59 = regs->r59; | ||||
| #else | ||||
| 	v2abi.r58 = v2abi.r59 = 0; | ||||
| #endif | ||||
| 	err = __copy_to_user(&mctx->v2abi, &v2abi, sizeof(v2abi)); | ||||
| #endif | ||||
| 	return err; | ||||
| } | ||||
| 
 | ||||
| static int restore_arcv2_regs(struct sigcontext *mctx, struct pt_regs *regs) | ||||
| { | ||||
| 	int err = 0; | ||||
| #ifndef CONFIG_ISA_ARCOMPACT | ||||
| 	struct user_regs_arcv2 v2abi; | ||||
| 
 | ||||
| 	err = __copy_from_user(&v2abi, &mctx->v2abi, sizeof(v2abi)); | ||||
| 
 | ||||
| 	regs->r30 = v2abi.r30; | ||||
| #ifdef CONFIG_ARC_HAS_ACCL_REGS | ||||
| 	regs->r58 = v2abi.r58; | ||||
| 	regs->r59 = v2abi.r59; | ||||
| #endif | ||||
| #endif | ||||
| 	return err; | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| stash_usr_regs(struct rt_sigframe __user *sf, struct pt_regs *regs, | ||||
| 	       sigset_t *set) | ||||
|  | @ -94,6 +129,10 @@ stash_usr_regs(struct rt_sigframe __user *sf, struct pt_regs *regs, | |||
| 
 | ||||
| 	err = __copy_to_user(&(sf->uc.uc_mcontext.regs.scratch), &uregs.scratch, | ||||
| 			     sizeof(sf->uc.uc_mcontext.regs.scratch)); | ||||
| 
 | ||||
| 	if (is_isa_arcv2()) | ||||
| 		err |= save_arcv2_regs(&(sf->uc.uc_mcontext), regs); | ||||
| 
 | ||||
| 	err |= __copy_to_user(&sf->uc.uc_sigmask, set, sizeof(sigset_t)); | ||||
| 
 | ||||
| 	return err ? -EFAULT : 0; | ||||
|  | @ -109,6 +148,10 @@ static int restore_usr_regs(struct pt_regs *regs, struct rt_sigframe __user *sf) | |||
| 	err |= __copy_from_user(&uregs.scratch, | ||||
| 				&(sf->uc.uc_mcontext.regs.scratch), | ||||
| 				sizeof(sf->uc.uc_mcontext.regs.scratch)); | ||||
| 
 | ||||
| 	if (is_isa_arcv2()) | ||||
| 		err |= restore_arcv2_regs(&(sf->uc.uc_mcontext), regs); | ||||
| 
 | ||||
| 	if (err) | ||||
| 		return -EFAULT; | ||||
| 
 | ||||
|  |  | |||
|  | @ -57,7 +57,6 @@ SECTIONS | |||
| 	.init.ramfs : { INIT_RAM_FS } | ||||
| 
 | ||||
| 	. = ALIGN(PAGE_SIZE);
 | ||||
| 	_stext = .;
 | ||||
| 
 | ||||
| 	HEAD_TEXT_SECTION | ||||
| 	INIT_TEXT_SECTION(L1_CACHE_BYTES) | ||||
|  | @ -83,6 +82,7 @@ SECTIONS | |||
| 
 | ||||
| 	.text : { | ||||
| 		_text = .;
 | ||||
| 		_stext = .;
 | ||||
| 		TEXT_TEXT | ||||
| 		SCHED_TEXT | ||||
| 		CPUIDLE_TEXT | ||||
|  |  | |||
|  | @ -105,9 +105,13 @@ | |||
| 	phy-reset-gpios = <&gpio1 25 GPIO_ACTIVE_LOW>; | ||||
| 	phy-reset-duration = <20>; | ||||
| 	phy-supply = <&sw2_reg>; | ||||
| 	phy-handle = <ðphy0>; | ||||
| 	status = "okay"; | ||||
| 
 | ||||
| 	fixed-link { | ||||
| 		speed = <1000>; | ||||
| 		full-duplex; | ||||
| 	}; | ||||
| 
 | ||||
| 	mdio { | ||||
| 		#address-cells = <1>; | ||||
| 		#size-cells = <0>; | ||||
|  |  | |||
|  | @ -406,6 +406,18 @@ | |||
| 	vin-supply = <&sw1_reg>; | ||||
| }; | ||||
| 
 | ||||
| ®_pu { | ||||
| 	vin-supply = <&sw1_reg>; | ||||
| }; | ||||
| 
 | ||||
| ®_vdd1p1 { | ||||
| 	vin-supply = <&sw2_reg>; | ||||
| }; | ||||
| 
 | ||||
| ®_vdd2p5 { | ||||
| 	vin-supply = <&sw2_reg>; | ||||
| }; | ||||
| 
 | ||||
| &uart1 { | ||||
| 	pinctrl-names = "default"; | ||||
| 	pinctrl-0 = <&pinctrl_uart1>; | ||||
|  |  | |||
|  | @ -126,7 +126,7 @@ | |||
| 		compatible = "nxp,pca8574"; | ||||
| 		reg = <0x3a>; | ||||
| 		gpio-controller; | ||||
| 		#gpio-cells = <1>; | ||||
| 		#gpio-cells = <2>; | ||||
| 	}; | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -193,7 +193,7 @@ | |||
| 	pinctrl-names = "default"; | ||||
| 	pinctrl-0 = <&pinctrl_usdhc1>; | ||||
| 	keep-power-in-suspend; | ||||
| 	tuning-step = <2>; | ||||
| 	fsl,tuning-step = <2>; | ||||
| 	vmmc-supply = <®_3p3v>; | ||||
| 	no-1-8-v; | ||||
| 	broken-cd; | ||||
|  |  | |||
|  | @ -351,7 +351,7 @@ | |||
| 	pinctrl-2 = <&pinctrl_usdhc1_200mhz>; | ||||
| 	cd-gpios = <&gpio5 0 GPIO_ACTIVE_LOW>; | ||||
| 	bus-width = <4>; | ||||
| 	tuning-step = <2>; | ||||
| 	fsl,tuning-step = <2>; | ||||
| 	vmmc-supply = <®_3p3v>; | ||||
| 	wakeup-source; | ||||
| 	no-1-8-v; | ||||
|  |  | |||
|  | @ -7,9 +7,11 @@ | |||
| #ifdef CONFIG_CPU_IDLE | ||||
| extern int arm_cpuidle_simple_enter(struct cpuidle_device *dev, | ||||
| 		struct cpuidle_driver *drv, int index); | ||||
| #define __cpuidle_method_section __used __section("__cpuidle_method_of_table") | ||||
| #else | ||||
| static inline int arm_cpuidle_simple_enter(struct cpuidle_device *dev, | ||||
| 		struct cpuidle_driver *drv, int index) { return -ENODEV; } | ||||
| #define __cpuidle_method_section __maybe_unused /* drop silently */ | ||||
| #endif | ||||
| 
 | ||||
| /* Common ARM WFI state */ | ||||
|  | @ -42,8 +44,7 @@ struct of_cpuidle_method { | |||
| 
 | ||||
| #define CPUIDLE_METHOD_OF_DECLARE(name, _method, _ops)			\ | ||||
| 	static const struct of_cpuidle_method __cpuidle_method_of_table_##name \ | ||||
| 	__used __section("__cpuidle_method_of_table")			\ | ||||
| 	= { .method = _method, .ops = _ops } | ||||
| 	__cpuidle_method_section = { .method = _method, .ops = _ops } | ||||
| 
 | ||||
| extern int arm_cpuidle_suspend(int index); | ||||
| 
 | ||||
|  |  | |||
|  | @ -12,6 +12,7 @@ | |||
| #include <linux/suspend.h> | ||||
| #include <linux/io.h> | ||||
| 
 | ||||
| #include "common.h" | ||||
| #include "hardware.h" | ||||
| 
 | ||||
| static int mx27_suspend_enter(suspend_state_t state) | ||||
|  |  | |||
|  | @ -458,20 +458,6 @@ static struct gpiod_lookup_table leds_gpio_table = { | |||
| 
 | ||||
| #ifdef CONFIG_LEDS_TRIGGERS | ||||
| DEFINE_LED_TRIGGER(ams_delta_camera_led_trigger); | ||||
| 
 | ||||
| static int ams_delta_camera_power(struct device *dev, int power) | ||||
| { | ||||
| 	/*
 | ||||
| 	 * turn on camera LED | ||||
| 	 */ | ||||
| 	if (power) | ||||
| 		led_trigger_event(ams_delta_camera_led_trigger, LED_FULL); | ||||
| 	else | ||||
| 		led_trigger_event(ams_delta_camera_led_trigger, LED_OFF); | ||||
| 	return 0; | ||||
| } | ||||
| #else | ||||
| #define ams_delta_camera_power	NULL | ||||
| #endif | ||||
| 
 | ||||
| static struct platform_device ams_delta_audio_device = { | ||||
|  |  | |||
|  | @ -320,7 +320,7 @@ static int tps_setup(struct i2c_client *client, void *context) | |||
| { | ||||
| 	if (!IS_BUILTIN(CONFIG_TPS65010)) | ||||
| 		return -ENOSYS; | ||||
| 	 | ||||
| 
 | ||||
| 	tps65010_config_vregs1(TPS_LDO2_ENABLE | TPS_VLDO2_3_0V | | ||||
| 				TPS_LDO1_ENABLE | TPS_VLDO1_3_0V); | ||||
| 
 | ||||
|  | @ -394,6 +394,8 @@ static void __init h2_init(void) | |||
| 	BUG_ON(gpio_request(H2_NAND_RB_GPIO_PIN, "NAND ready") < 0); | ||||
| 	gpio_direction_input(H2_NAND_RB_GPIO_PIN); | ||||
| 
 | ||||
| 	gpiod_add_lookup_table(&isp1301_gpiod_table); | ||||
| 
 | ||||
| 	omap_cfg_reg(L3_1610_FLASH_CS2B_OE); | ||||
| 	omap_cfg_reg(M8_1610_FLASH_CS2B_WE); | ||||
| 
 | ||||
|  |  | |||
|  | @ -655,9 +655,13 @@ static int __init omap_pm_init(void) | |||
| 		irq = INT_7XX_WAKE_UP_REQ; | ||||
| 	else if (cpu_is_omap16xx()) | ||||
| 		irq = INT_1610_WAKE_UP_REQ; | ||||
| 	if (request_irq(irq, omap_wakeup_interrupt, 0, "peripheral wakeup", | ||||
| 			NULL)) | ||||
| 		pr_err("Failed to request irq %d (peripheral wakeup)\n", irq); | ||||
| 	else | ||||
| 		irq = -1; | ||||
| 
 | ||||
| 	if (irq >= 0) { | ||||
| 		if (request_irq(irq, omap_wakeup_interrupt, 0, "peripheral wakeup", NULL)) | ||||
| 			pr_err("Failed to request irq %d (peripheral wakeup)\n", irq); | ||||
| 	} | ||||
| 
 | ||||
| 	/* Program new power ramp-up time
 | ||||
| 	 * (0 for most boards since we don't lower voltage when in deep sleep) | ||||
|  |  | |||
|  | @ -322,6 +322,7 @@ static int n8x0_mmc_get_cover_state(struct device *dev, int slot) | |||
| 
 | ||||
| static void n8x0_mmc_callback(void *data, u8 card_mask) | ||||
| { | ||||
| #ifdef CONFIG_MMC_OMAP | ||||
| 	int bit, *openp, index; | ||||
| 
 | ||||
| 	if (board_is_n800()) { | ||||
|  | @ -339,7 +340,6 @@ static void n8x0_mmc_callback(void *data, u8 card_mask) | |||
| 	else | ||||
| 		*openp = 0; | ||||
| 
 | ||||
| #ifdef CONFIG_MMC_OMAP | ||||
| 	omap_mmc_notify_cover_event(mmc_device, index, *openp); | ||||
| #else | ||||
| 	pr_warn("MMC: notify cover event not available\n"); | ||||
|  |  | |||
|  | @ -165,6 +165,7 @@ config ARCH_MEDIATEK | |||
| 
 | ||||
| config ARCH_MESON | ||||
| 	bool "Amlogic Platforms" | ||||
| 	select COMMON_CLK | ||||
| 	select MESON_IRQ_GPIO | ||||
| 	help | ||||
| 	  This enables support for the arm64 based Amlogic SoCs | ||||
|  |  | |||
|  | @ -46,7 +46,8 @@ | |||
| 			eee-broken-100tx; | ||||
| 			qca,clk-out-frequency = <125000000>; | ||||
| 			qca,clk-out-strength = <AR803X_STRENGTH_FULL>; | ||||
| 			vddio-supply = <&vddh>; | ||||
| 			qca,keep-pll-enabled; | ||||
| 			vddio-supply = <&vddio>; | ||||
| 
 | ||||
| 			vddio: vddio-regulator { | ||||
| 				regulator-name = "VDDIO"; | ||||
|  |  | |||
|  | @ -31,11 +31,10 @@ | |||
| 			reg = <0x4>; | ||||
| 			eee-broken-1000t; | ||||
| 			eee-broken-100tx; | ||||
| 
 | ||||
| 			qca,clk-out-frequency = <125000000>; | ||||
| 			qca,clk-out-strength = <AR803X_STRENGTH_FULL>; | ||||
| 
 | ||||
| 			vddio-supply = <&vddh>; | ||||
| 			qca,keep-pll-enabled; | ||||
| 			vddio-supply = <&vddio>; | ||||
| 
 | ||||
| 			vddio: vddio-regulator { | ||||
| 				regulator-name = "VDDIO"; | ||||
|  |  | |||
|  | @ -197,8 +197,8 @@ | |||
| 		ddr: memory-controller@1080000 { | ||||
| 			compatible = "fsl,qoriq-memory-controller"; | ||||
| 			reg = <0x0 0x1080000 0x0 0x1000>; | ||||
| 			interrupts = <GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 			big-endian; | ||||
| 			interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 			little-endian; | ||||
| 		}; | ||||
| 
 | ||||
| 		dcfg: syscon@1e00000 { | ||||
|  |  | |||
|  | @ -88,11 +88,11 @@ | |||
| 		pinctrl-0 = <&pinctrl_codec2>; | ||||
| 		reg = <0x18>; | ||||
| 		#sound-dai-cells = <0>; | ||||
| 		HPVDD-supply = <®_3p3v>; | ||||
| 		SPRVDD-supply = <®_3p3v>; | ||||
| 		SPLVDD-supply = <®_3p3v>; | ||||
| 		AVDD-supply = <®_3p3v>; | ||||
| 		IOVDD-supply = <®_3p3v>; | ||||
| 		HPVDD-supply = <®_gen_3p3>; | ||||
| 		SPRVDD-supply = <®_gen_3p3>; | ||||
| 		SPLVDD-supply = <®_gen_3p3>; | ||||
| 		AVDD-supply = <®_gen_3p3>; | ||||
| 		IOVDD-supply = <®_gen_3p3>; | ||||
| 		DVDD-supply = <&vgen4_reg>; | ||||
| 		reset-gpios = <&gpio3 4 GPIO_ACTIVE_HIGH>; | ||||
| 	}; | ||||
|  |  | |||
|  | @ -45,8 +45,8 @@ | |||
| 	reg_12p0_main: regulator-12p0-main { | ||||
| 		compatible = "regulator-fixed"; | ||||
| 		regulator-name = "12V_MAIN"; | ||||
| 		regulator-min-microvolt = <5000000>; | ||||
| 		regulator-max-microvolt = <5000000>; | ||||
| 		regulator-min-microvolt = <12000000>; | ||||
| 		regulator-max-microvolt = <12000000>; | ||||
| 		regulator-always-on; | ||||
| 	}; | ||||
| 
 | ||||
|  | @ -77,15 +77,6 @@ | |||
| 		regulator-always-on; | ||||
| 	}; | ||||
| 
 | ||||
| 	reg_3p3v: regulator-3p3v { | ||||
| 		compatible = "regulator-fixed"; | ||||
| 		vin-supply = <®_3p3_main>; | ||||
| 		regulator-name = "GEN_3V3"; | ||||
| 		regulator-min-microvolt = <3300000>; | ||||
| 		regulator-max-microvolt = <3300000>; | ||||
| 		regulator-always-on; | ||||
| 	}; | ||||
| 
 | ||||
| 	reg_usdhc2_vmmc: regulator-vsd-3v3 { | ||||
| 		pinctrl-names = "default"; | ||||
| 		pinctrl-0 = <&pinctrl_reg_usdhc2>; | ||||
|  | @ -415,11 +406,11 @@ | |||
| 		pinctrl-0 = <&pinctrl_codec1>; | ||||
| 		reg = <0x18>; | ||||
| 		#sound-dai-cells = <0>; | ||||
| 		HPVDD-supply = <®_3p3v>; | ||||
| 		SPRVDD-supply = <®_3p3v>; | ||||
| 		SPLVDD-supply = <®_3p3v>; | ||||
| 		AVDD-supply = <®_3p3v>; | ||||
| 		IOVDD-supply = <®_3p3v>; | ||||
| 		HPVDD-supply = <®_gen_3p3>; | ||||
| 		SPRVDD-supply = <®_gen_3p3>; | ||||
| 		SPLVDD-supply = <®_gen_3p3>; | ||||
| 		AVDD-supply = <®_gen_3p3>; | ||||
| 		IOVDD-supply = <®_gen_3p3>; | ||||
| 		DVDD-supply = <&vgen4_reg>; | ||||
| 		reset-gpios = <&gpio3 3 GPIO_ACTIVE_LOW>; | ||||
| 	}; | ||||
|  |  | |||
|  | @ -42,12 +42,12 @@ | |||
| 		}; | ||||
| 	}; | ||||
| 
 | ||||
| 	dmss: dmss { | ||||
| 	dmss: bus@48000000 { | ||||
| 		compatible = "simple-mfd"; | ||||
| 		#address-cells = <2>; | ||||
| 		#size-cells = <2>; | ||||
| 		dma-ranges; | ||||
| 		ranges; | ||||
| 		ranges = <0x00 0x48000000 0x00 0x48000000 0x00 0x06400000>; | ||||
| 
 | ||||
| 		ti,sci-dev-id = <25>; | ||||
| 
 | ||||
|  | @ -134,7 +134,7 @@ | |||
| 		}; | ||||
| 	}; | ||||
| 
 | ||||
| 	dmsc: dmsc@44043000 { | ||||
| 	dmsc: system-controller@44043000 { | ||||
| 		compatible = "ti,k2g-sci"; | ||||
| 		ti,host-id = <12>; | ||||
| 		mbox-names = "rx", "tx"; | ||||
|  | @ -148,7 +148,7 @@ | |||
| 			#power-domain-cells = <2>; | ||||
| 		}; | ||||
| 
 | ||||
| 		k3_clks: clocks { | ||||
| 		k3_clks: clock-controller { | ||||
| 			compatible = "ti,k2g-sci-clk"; | ||||
| 			#clock-cells = <2>; | ||||
| 		}; | ||||
|  | @ -373,8 +373,9 @@ | |||
| 		clocks = <&k3_clks 145 0>; | ||||
| 	}; | ||||
| 
 | ||||
| 	main_gpio_intr: interrupt-controller0 { | ||||
| 	main_gpio_intr: interrupt-controller@a00000 { | ||||
| 		compatible = "ti,sci-intr"; | ||||
| 		reg = <0x00 0x00a00000 0x00 0x800>; | ||||
| 		ti,intr-trigger-type = <1>; | ||||
| 		interrupt-controller; | ||||
| 		interrupt-parent = <&gic500>; | ||||
|  |  | |||
|  | @ -74,8 +74,9 @@ | |||
| 		clocks = <&k3_clks 148 0>; | ||||
| 	}; | ||||
| 
 | ||||
| 	mcu_gpio_intr: interrupt-controller1 { | ||||
| 	mcu_gpio_intr: interrupt-controller@4210000 { | ||||
| 		compatible = "ti,sci-intr"; | ||||
| 		reg = <0x00 0x04210000 0x00 0x200>; | ||||
| 		ti,intr-trigger-type = <1>; | ||||
| 		interrupt-controller; | ||||
| 		interrupt-parent = <&gic500>; | ||||
|  |  | |||
|  | @ -433,8 +433,9 @@ | |||
| 		#phy-cells = <0>; | ||||
| 	}; | ||||
| 
 | ||||
| 	intr_main_gpio: interrupt-controller0 { | ||||
| 	intr_main_gpio: interrupt-controller@a00000 { | ||||
| 		compatible = "ti,sci-intr"; | ||||
| 		reg = <0x0 0x00a00000 0x0 0x400>; | ||||
| 		ti,intr-trigger-type = <1>; | ||||
| 		interrupt-controller; | ||||
| 		interrupt-parent = <&gic500>; | ||||
|  | @ -444,18 +445,19 @@ | |||
| 		ti,interrupt-ranges = <0 392 32>; | ||||
| 	}; | ||||
| 
 | ||||
| 	main-navss { | ||||
| 	main_navss: bus@30800000 { | ||||
| 		compatible = "simple-mfd"; | ||||
| 		#address-cells = <2>; | ||||
| 		#size-cells = <2>; | ||||
| 		ranges; | ||||
| 		ranges = <0x0 0x30800000 0x0 0x30800000 0x0 0xbc00000>; | ||||
| 		dma-coherent; | ||||
| 		dma-ranges; | ||||
| 
 | ||||
| 		ti,sci-dev-id = <118>; | ||||
| 
 | ||||
| 		intr_main_navss: interrupt-controller1 { | ||||
| 		intr_main_navss: interrupt-controller@310e0000 { | ||||
| 			compatible = "ti,sci-intr"; | ||||
| 			reg = <0x0 0x310e0000 0x0 0x2000>; | ||||
| 			ti,intr-trigger-type = <4>; | ||||
| 			interrupt-controller; | ||||
| 			interrupt-parent = <&gic500>; | ||||
|  |  | |||
|  | @ -116,11 +116,11 @@ | |||
| 		}; | ||||
| 	}; | ||||
| 
 | ||||
| 	mcu-navss { | ||||
| 	mcu_navss: bus@28380000 { | ||||
| 		compatible = "simple-mfd"; | ||||
| 		#address-cells = <2>; | ||||
| 		#size-cells = <2>; | ||||
| 		ranges; | ||||
| 		ranges = <0x00 0x28380000 0x00 0x28380000 0x00 0x03880000>; | ||||
| 		dma-coherent; | ||||
| 		dma-ranges; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,24 +6,24 @@ | |||
|  */ | ||||
| 
 | ||||
| &cbass_wakeup { | ||||
| 	dmsc: dmsc { | ||||
| 	dmsc: system-controller@44083000 { | ||||
| 		compatible = "ti,am654-sci"; | ||||
| 		ti,host-id = <12>; | ||||
| 		#address-cells = <1>; | ||||
| 		#size-cells = <1>; | ||||
| 		ranges; | ||||
| 
 | ||||
| 		mbox-names = "rx", "tx"; | ||||
| 
 | ||||
| 		mboxes= <&secure_proxy_main 11>, | ||||
| 			<&secure_proxy_main 13>; | ||||
| 
 | ||||
| 		reg-names = "debug_messages"; | ||||
| 		reg = <0x44083000 0x1000>; | ||||
| 
 | ||||
| 		k3_pds: power-controller { | ||||
| 			compatible = "ti,sci-pm-domain"; | ||||
| 			#power-domain-cells = <2>; | ||||
| 		}; | ||||
| 
 | ||||
| 		k3_clks: clocks { | ||||
| 		k3_clks: clock-controller { | ||||
| 			compatible = "ti,k2g-sci-clk"; | ||||
| 			#clock-cells = <2>; | ||||
| 		}; | ||||
|  | @ -69,8 +69,9 @@ | |||
| 		power-domains = <&k3_pds 115 TI_SCI_PD_EXCLUSIVE>; | ||||
| 	}; | ||||
| 
 | ||||
| 	intr_wkup_gpio: interrupt-controller2 { | ||||
| 	intr_wkup_gpio: interrupt-controller@42200000 { | ||||
| 		compatible = "ti,sci-intr"; | ||||
| 		reg = <0x42200000 0x200>; | ||||
| 		ti,intr-trigger-type = <1>; | ||||
| 		interrupt-controller; | ||||
| 		interrupt-parent = <&gic500>; | ||||
|  |  | |||
|  | @ -85,12 +85,6 @@ | |||
| 			gpios = <&wkup_gpio0 27 GPIO_ACTIVE_LOW>; | ||||
| 		}; | ||||
| 	}; | ||||
| 
 | ||||
| 	clk_ov5640_fixed: clock { | ||||
| 		compatible = "fixed-clock"; | ||||
| 		#clock-cells = <0>; | ||||
| 		clock-frequency = <24000000>; | ||||
| 	}; | ||||
| }; | ||||
| 
 | ||||
| &wkup_pmx0 { | ||||
|  | @ -287,23 +281,6 @@ | |||
| 	pinctrl-names = "default"; | ||||
| 	pinctrl-0 = <&main_i2c1_pins_default>; | ||||
| 	clock-frequency = <400000>; | ||||
| 
 | ||||
| 	ov5640: camera@3c { | ||||
| 		compatible = "ovti,ov5640"; | ||||
| 		reg = <0x3c>; | ||||
| 
 | ||||
| 		clocks = <&clk_ov5640_fixed>; | ||||
| 		clock-names = "xclk"; | ||||
| 
 | ||||
| 		port { | ||||
| 			csi2_cam0: endpoint { | ||||
| 				remote-endpoint = <&csi2_phy0>; | ||||
| 				clock-lanes = <0>; | ||||
| 				data-lanes = <1 2>; | ||||
| 			}; | ||||
| 		}; | ||||
| 	}; | ||||
| 
 | ||||
| }; | ||||
| 
 | ||||
| &main_i2c2 { | ||||
|  | @ -496,14 +473,6 @@ | |||
| 	}; | ||||
| }; | ||||
| 
 | ||||
| &csi2_0 { | ||||
| 	csi2_phy0: endpoint { | ||||
| 		remote-endpoint = <&csi2_cam0>; | ||||
| 		clock-lanes = <0>; | ||||
| 		data-lanes = <1 2>; | ||||
| 	}; | ||||
| }; | ||||
| 
 | ||||
| &mcu_cpsw { | ||||
| 	pinctrl-names = "default"; | ||||
| 	pinctrl-0 = <&mcu_cpsw_pins_default &mcu_mdio_pins_default>; | ||||
|  |  | |||
|  | @ -68,8 +68,9 @@ | |||
| 		}; | ||||
| 	}; | ||||
| 
 | ||||
| 	main_gpio_intr: interrupt-controller0 { | ||||
| 	main_gpio_intr: interrupt-controller@a00000 { | ||||
| 		compatible = "ti,sci-intr"; | ||||
| 		reg = <0x00 0x00a00000 0x00 0x800>; | ||||
| 		ti,intr-trigger-type = <1>; | ||||
| 		interrupt-controller; | ||||
| 		interrupt-parent = <&gic500>; | ||||
|  | @ -85,9 +86,12 @@ | |||
| 		#size-cells = <2>; | ||||
| 		ranges = <0x00 0x30000000 0x00 0x30000000 0x00 0x0c400000>; | ||||
| 		ti,sci-dev-id = <199>; | ||||
| 		dma-coherent; | ||||
| 		dma-ranges; | ||||
| 
 | ||||
| 		main_navss_intr: interrupt-controller1 { | ||||
| 		main_navss_intr: interrupt-controller@310e0000 { | ||||
| 			compatible = "ti,sci-intr"; | ||||
| 			reg = <0x00 0x310e0000 0x00 0x4000>; | ||||
| 			ti,intr-trigger-type = <4>; | ||||
| 			interrupt-controller; | ||||
| 			interrupt-parent = <&gic500>; | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
|  */ | ||||
| 
 | ||||
| &cbass_mcu_wakeup { | ||||
| 	dmsc: dmsc@44083000 { | ||||
| 	dmsc: system-controller@44083000 { | ||||
| 		compatible = "ti,k2g-sci"; | ||||
| 		ti,host-id = <12>; | ||||
| 
 | ||||
|  | @ -23,7 +23,7 @@ | |||
| 			#power-domain-cells = <2>; | ||||
| 		}; | ||||
| 
 | ||||
| 		k3_clks: clocks { | ||||
| 		k3_clks: clock-controller { | ||||
| 			compatible = "ti,k2g-sci-clk"; | ||||
| 			#clock-cells = <2>; | ||||
| 		}; | ||||
|  | @ -96,8 +96,9 @@ | |||
| 		clock-names = "fclk"; | ||||
| 	}; | ||||
| 
 | ||||
| 	wkup_gpio_intr: interrupt-controller2 { | ||||
| 	wkup_gpio_intr: interrupt-controller@42200000 { | ||||
| 		compatible = "ti,sci-intr"; | ||||
| 		reg = <0x00 0x42200000 0x00 0x400>; | ||||
| 		ti,intr-trigger-type = <1>; | ||||
| 		interrupt-controller; | ||||
| 		interrupt-parent = <&gic500>; | ||||
|  |  | |||
|  | @ -76,8 +76,9 @@ | |||
| 		}; | ||||
| 	}; | ||||
| 
 | ||||
| 	main_gpio_intr: interrupt-controller0 { | ||||
| 	main_gpio_intr: interrupt-controller@a00000 { | ||||
| 		compatible = "ti,sci-intr"; | ||||
| 		reg = <0x00 0x00a00000 0x00 0x800>; | ||||
| 		ti,intr-trigger-type = <1>; | ||||
| 		interrupt-controller; | ||||
| 		interrupt-parent = <&gic500>; | ||||
|  | @ -87,18 +88,19 @@ | |||
| 		ti,interrupt-ranges = <8 392 56>; | ||||
| 	}; | ||||
| 
 | ||||
| 	main-navss { | ||||
| 	main_navss: bus@30000000 { | ||||
| 		compatible = "simple-mfd"; | ||||
| 		#address-cells = <2>; | ||||
| 		#size-cells = <2>; | ||||
| 		ranges; | ||||
| 		ranges = <0x00 0x30000000 0x00 0x30000000 0x00 0x0c400000>; | ||||
| 		dma-coherent; | ||||
| 		dma-ranges; | ||||
| 
 | ||||
| 		ti,sci-dev-id = <199>; | ||||
| 
 | ||||
| 		main_navss_intr: interrupt-controller1 { | ||||
| 		main_navss_intr: interrupt-controller@310e0000 { | ||||
| 			compatible = "ti,sci-intr"; | ||||
| 			reg = <0x0 0x310e0000 0x0 0x4000>; | ||||
| 			ti,intr-trigger-type = <4>; | ||||
| 			interrupt-controller; | ||||
| 			interrupt-parent = <&gic500>; | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
|  */ | ||||
| 
 | ||||
| &cbass_mcu_wakeup { | ||||
| 	dmsc: dmsc@44083000 { | ||||
| 	dmsc: system-controller@44083000 { | ||||
| 		compatible = "ti,k2g-sci"; | ||||
| 		ti,host-id = <12>; | ||||
| 
 | ||||
|  | @ -23,7 +23,7 @@ | |||
| 			#power-domain-cells = <2>; | ||||
| 		}; | ||||
| 
 | ||||
| 		k3_clks: clocks { | ||||
| 		k3_clks: clock-controller { | ||||
| 			compatible = "ti,k2g-sci-clk"; | ||||
| 			#clock-cells = <2>; | ||||
| 		}; | ||||
|  | @ -96,8 +96,9 @@ | |||
| 		clock-names = "fclk"; | ||||
| 	}; | ||||
| 
 | ||||
| 	wkup_gpio_intr: interrupt-controller2 { | ||||
| 	wkup_gpio_intr: interrupt-controller@42200000 { | ||||
| 		compatible = "ti,sci-intr"; | ||||
| 		reg = <0x00 0x42200000 0x00 0x400>; | ||||
| 		ti,intr-trigger-type = <1>; | ||||
| 		interrupt-controller; | ||||
| 		interrupt-parent = <&gic500>; | ||||
|  | @ -249,11 +250,11 @@ | |||
| 		}; | ||||
| 	}; | ||||
| 
 | ||||
| 	mcu-navss { | ||||
| 	mcu_navss: bus@28380000 { | ||||
| 		compatible = "simple-mfd"; | ||||
| 		#address-cells = <2>; | ||||
| 		#size-cells = <2>; | ||||
| 		ranges; | ||||
| 		ranges = <0x00 0x28380000 0x00 0x28380000 0x00 0x03880000>; | ||||
| 		dma-coherent; | ||||
| 		dma-ranges; | ||||
| 
 | ||||
|  |  | |||
|  | @ -158,31 +158,29 @@ unsigned long _page_cachable_default; | |||
| EXPORT_SYMBOL(_page_cachable_default); | ||||
| 
 | ||||
| #define PM(p)	__pgprot(_page_cachable_default | (p)) | ||||
| #define PVA(p)	PM(_PAGE_VALID | _PAGE_ACCESSED | (p)) | ||||
| 
 | ||||
| static inline void setup_protection_map(void) | ||||
| { | ||||
| 	protection_map[0]  = PM(_PAGE_PRESENT | _PAGE_NO_EXEC | _PAGE_NO_READ); | ||||
| 	protection_map[1]  = PVA(_PAGE_PRESENT | _PAGE_NO_EXEC); | ||||
| 	protection_map[2]  = PVA(_PAGE_PRESENT | _PAGE_NO_EXEC | _PAGE_NO_READ); | ||||
| 	protection_map[3]  = PVA(_PAGE_PRESENT | _PAGE_NO_EXEC); | ||||
| 	protection_map[4]  = PVA(_PAGE_PRESENT); | ||||
| 	protection_map[5]  = PVA(_PAGE_PRESENT); | ||||
| 	protection_map[6]  = PVA(_PAGE_PRESENT); | ||||
| 	protection_map[7]  = PVA(_PAGE_PRESENT); | ||||
| 	protection_map[1]  = PM(_PAGE_PRESENT | _PAGE_NO_EXEC); | ||||
| 	protection_map[2]  = PM(_PAGE_PRESENT | _PAGE_NO_EXEC | _PAGE_NO_READ); | ||||
| 	protection_map[3]  = PM(_PAGE_PRESENT | _PAGE_NO_EXEC); | ||||
| 	protection_map[4]  = PM(_PAGE_PRESENT); | ||||
| 	protection_map[5]  = PM(_PAGE_PRESENT); | ||||
| 	protection_map[6]  = PM(_PAGE_PRESENT); | ||||
| 	protection_map[7]  = PM(_PAGE_PRESENT); | ||||
| 
 | ||||
| 	protection_map[8]  = PM(_PAGE_PRESENT | _PAGE_NO_EXEC | _PAGE_NO_READ); | ||||
| 	protection_map[9]  = PVA(_PAGE_PRESENT | _PAGE_NO_EXEC); | ||||
| 	protection_map[10] = PVA(_PAGE_PRESENT | _PAGE_NO_EXEC | _PAGE_WRITE | | ||||
| 	protection_map[9]  = PM(_PAGE_PRESENT | _PAGE_NO_EXEC); | ||||
| 	protection_map[10] = PM(_PAGE_PRESENT | _PAGE_NO_EXEC | _PAGE_WRITE | | ||||
| 				_PAGE_NO_READ); | ||||
| 	protection_map[11] = PVA(_PAGE_PRESENT | _PAGE_NO_EXEC | _PAGE_WRITE); | ||||
| 	protection_map[12] = PVA(_PAGE_PRESENT); | ||||
| 	protection_map[13] = PVA(_PAGE_PRESENT); | ||||
| 	protection_map[14] = PVA(_PAGE_PRESENT); | ||||
| 	protection_map[15] = PVA(_PAGE_PRESENT); | ||||
| 	protection_map[11] = PM(_PAGE_PRESENT | _PAGE_NO_EXEC | _PAGE_WRITE); | ||||
| 	protection_map[12] = PM(_PAGE_PRESENT); | ||||
| 	protection_map[13] = PM(_PAGE_PRESENT); | ||||
| 	protection_map[14] = PM(_PAGE_PRESENT | _PAGE_WRITE); | ||||
| 	protection_map[15] = PM(_PAGE_PRESENT | _PAGE_WRITE); | ||||
| } | ||||
| 
 | ||||
| #undef _PVA | ||||
| #undef PM | ||||
| 
 | ||||
| void cpu_cache_init(void) | ||||
|  |  | |||
|  | @ -50,7 +50,7 @@ l_yes: | |||
| 1098:	nop;					\ | ||||
| 	.pushsection __jump_table, "aw";	\ | ||||
| 	.long 1098b - ., LABEL - .;		\ | ||||
| 	FTR_ENTRY_LONG KEY;			\ | ||||
| 	FTR_ENTRY_LONG KEY - .;			\ | ||||
| 	.popsection | ||||
| #endif | ||||
| 
 | ||||
|  |  | |||
|  | @ -31,6 +31,35 @@ static inline pte_t *find_init_mm_pte(unsigned long ea, unsigned *hshift) | |||
| 	pgd_t *pgdir = init_mm.pgd; | ||||
| 	return __find_linux_pte(pgdir, ea, NULL, hshift); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Convert a kernel vmap virtual address (vmalloc or ioremap space) to a | ||||
|  * physical address, without taking locks. This can be used in real-mode. | ||||
|  */ | ||||
| static inline phys_addr_t ppc_find_vmap_phys(unsigned long addr) | ||||
| { | ||||
| 	pte_t *ptep; | ||||
| 	phys_addr_t pa; | ||||
| 	int hugepage_shift; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * init_mm does not free page tables, and does not do THP. It may | ||||
| 	 * have huge pages from huge vmalloc / ioremap etc. | ||||
| 	 */ | ||||
| 	ptep = find_init_mm_pte(addr, &hugepage_shift); | ||||
| 	if (WARN_ON(!ptep)) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	pa = PFN_PHYS(pte_pfn(*ptep)); | ||||
| 
 | ||||
| 	if (!hugepage_shift) | ||||
| 		hugepage_shift = PAGE_SHIFT; | ||||
| 
 | ||||
| 	pa |= addr & ((1ul << hugepage_shift) - 1); | ||||
| 
 | ||||
| 	return pa; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * This is what we should always use. Any other lockless page table lookup needs | ||||
|  * careful audit against THP split. | ||||
|  |  | |||
|  | @ -346,28 +346,7 @@ void eeh_slot_error_detail(struct eeh_pe *pe, int severity) | |||
|  */ | ||||
| static inline unsigned long eeh_token_to_phys(unsigned long token) | ||||
| { | ||||
| 	pte_t *ptep; | ||||
| 	unsigned long pa; | ||||
| 	int hugepage_shift; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * We won't find hugepages here(this is iomem). Hence we are not | ||||
| 	 * worried about _PAGE_SPLITTING/collapse. Also we will not hit | ||||
| 	 * page table free, because of init_mm. | ||||
| 	 */ | ||||
| 	ptep = find_init_mm_pte(token, &hugepage_shift); | ||||
| 	if (!ptep) | ||||
| 		return token; | ||||
| 
 | ||||
| 	pa = pte_pfn(*ptep); | ||||
| 
 | ||||
| 	/* On radix we can do hugepage mappings for io, so handle that */ | ||||
| 	if (!hugepage_shift) | ||||
| 		hugepage_shift = PAGE_SHIFT; | ||||
| 
 | ||||
| 	pa <<= PAGE_SHIFT; | ||||
| 	pa |= token & ((1ul << hugepage_shift) - 1); | ||||
| 	return pa; | ||||
| 	return ppc_find_vmap_phys(token); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  |  | |||
|  | @ -55,7 +55,6 @@ static struct iowa_bus *iowa_pci_find(unsigned long vaddr, unsigned long paddr) | |||
| #ifdef CONFIG_PPC_INDIRECT_MMIO | ||||
| struct iowa_bus *iowa_mem_find_bus(const PCI_IO_ADDR addr) | ||||
| { | ||||
| 	unsigned hugepage_shift; | ||||
| 	struct iowa_bus *bus; | ||||
| 	int token; | ||||
| 
 | ||||
|  | @ -65,22 +64,13 @@ struct iowa_bus *iowa_mem_find_bus(const PCI_IO_ADDR addr) | |||
| 		bus = &iowa_busses[token - 1]; | ||||
| 	else { | ||||
| 		unsigned long vaddr, paddr; | ||||
| 		pte_t *ptep; | ||||
| 
 | ||||
| 		vaddr = (unsigned long)PCI_FIX_ADDR(addr); | ||||
| 		if (vaddr < PHB_IO_BASE || vaddr >= PHB_IO_END) | ||||
| 			return NULL; | ||||
| 		/*
 | ||||
| 		 * We won't find huge pages here (iomem). Also can't hit | ||||
| 		 * a page table free due to init_mm | ||||
| 		 */ | ||||
| 		ptep = find_init_mm_pte(vaddr, &hugepage_shift); | ||||
| 		if (ptep == NULL) | ||||
| 			paddr = 0; | ||||
| 		else { | ||||
| 			WARN_ON(hugepage_shift); | ||||
| 			paddr = pte_pfn(*ptep) << PAGE_SHIFT; | ||||
| 		} | ||||
| 
 | ||||
| 		paddr = ppc_find_vmap_phys(vaddr); | ||||
| 
 | ||||
| 		bus = iowa_pci_find(vaddr, paddr); | ||||
| 
 | ||||
| 		if (bus == NULL) | ||||
|  |  | |||
|  | @ -898,7 +898,6 @@ void *iommu_alloc_coherent(struct device *dev, struct iommu_table *tbl, | |||
| 	unsigned int order; | ||||
| 	unsigned int nio_pages, io_order; | ||||
| 	struct page *page; | ||||
| 	size_t size_io = size; | ||||
| 
 | ||||
| 	size = PAGE_ALIGN(size); | ||||
| 	order = get_order(size); | ||||
|  | @ -925,9 +924,8 @@ void *iommu_alloc_coherent(struct device *dev, struct iommu_table *tbl, | |||
| 	memset(ret, 0, size); | ||||
| 
 | ||||
| 	/* Set up tces to cover the allocated range */ | ||||
| 	size_io = IOMMU_PAGE_ALIGN(size_io, tbl); | ||||
| 	nio_pages = size_io >> tbl->it_page_shift; | ||||
| 	io_order = get_iommu_order(size_io, tbl); | ||||
| 	nio_pages = size >> tbl->it_page_shift; | ||||
| 	io_order = get_iommu_order(size, tbl); | ||||
| 	mapping = iommu_alloc(dev, tbl, ret, nio_pages, DMA_BIDIRECTIONAL, | ||||
| 			      mask >> tbl->it_page_shift, io_order, 0); | ||||
| 	if (mapping == DMA_MAPPING_ERROR) { | ||||
|  | @ -942,9 +940,10 @@ void iommu_free_coherent(struct iommu_table *tbl, size_t size, | |||
| 			 void *vaddr, dma_addr_t dma_handle) | ||||
| { | ||||
| 	if (tbl) { | ||||
| 		size_t size_io = IOMMU_PAGE_ALIGN(size, tbl); | ||||
| 		unsigned int nio_pages = size_io >> tbl->it_page_shift; | ||||
| 		unsigned int nio_pages; | ||||
| 
 | ||||
| 		size = PAGE_ALIGN(size); | ||||
| 		nio_pages = size >> tbl->it_page_shift; | ||||
| 		iommu_free(tbl, dma_handle, nio_pages); | ||||
| 		size = PAGE_ALIGN(size); | ||||
| 		free_pages((unsigned long)vaddr, get_order(size)); | ||||
|  |  | |||
|  | @ -108,7 +108,6 @@ int arch_prepare_kprobe(struct kprobe *p) | |||
| 	int ret = 0; | ||||
| 	struct kprobe *prev; | ||||
| 	struct ppc_inst insn = ppc_inst_read((struct ppc_inst *)p->addr); | ||||
| 	struct ppc_inst prefix = ppc_inst_read((struct ppc_inst *)(p->addr - 1)); | ||||
| 
 | ||||
| 	if ((unsigned long)p->addr & 0x03) { | ||||
| 		printk("Attempt to register kprobe at an unaligned address\n"); | ||||
|  | @ -116,7 +115,8 @@ int arch_prepare_kprobe(struct kprobe *p) | |||
| 	} else if (IS_MTMSRD(insn) || IS_RFID(insn) || IS_RFI(insn)) { | ||||
| 		printk("Cannot register a kprobe on rfi/rfid or mtmsr[d]\n"); | ||||
| 		ret = -EINVAL; | ||||
| 	} else if (ppc_inst_prefixed(prefix)) { | ||||
| 	} else if ((unsigned long)p->addr & ~PAGE_MASK && | ||||
| 		   ppc_inst_prefixed(ppc_inst_read((struct ppc_inst *)(p->addr - 1)))) { | ||||
| 		printk("Cannot register a kprobe on the second word of prefixed instruction\n"); | ||||
| 		ret = -EINVAL; | ||||
| 	} | ||||
|  |  | |||
|  | @ -902,6 +902,10 @@ int handle_rt_signal64(struct ksignal *ksig, sigset_t *set, | |||
| 	unsafe_copy_to_user(&frame->uc.uc_sigmask, set, sizeof(*set), badframe_block); | ||||
| 	user_write_access_end(); | ||||
| 
 | ||||
| 	/* Save the siginfo outside of the unsafe block. */ | ||||
| 	if (copy_siginfo_to_user(&frame->info, &ksig->info)) | ||||
| 		goto badframe; | ||||
| 
 | ||||
| 	/* Make sure signal handler doesn't get spurious FP exceptions */ | ||||
| 	tsk->thread.fp_state.fpscr = 0; | ||||
| 
 | ||||
|  | @ -915,11 +919,6 @@ int handle_rt_signal64(struct ksignal *ksig, sigset_t *set, | |||
| 		regs->nip = (unsigned long) &frame->tramp[0]; | ||||
| 	} | ||||
| 
 | ||||
| 
 | ||||
| 	/* Save the siginfo outside of the unsafe block. */ | ||||
| 	if (copy_siginfo_to_user(&frame->info, &ksig->info)) | ||||
| 		goto badframe; | ||||
| 
 | ||||
| 	/* Allocate a dummy caller frame for the signal handler. */ | ||||
| 	newsp = ((unsigned long)frame) - __SIGNAL_FRAMESIZE; | ||||
| 	err |= put_user(regs->gpr[1], (unsigned long __user *)newsp); | ||||
|  |  | |||
|  | @ -23,20 +23,9 @@ | |||
| #include <asm/pte-walk.h> | ||||
| 
 | ||||
| /* Translate address of a vmalloc'd thing to a linear map address */ | ||||
| static void *real_vmalloc_addr(void *x) | ||||
| static void *real_vmalloc_addr(void *addr) | ||||
| { | ||||
| 	unsigned long addr = (unsigned long) x; | ||||
| 	pte_t *p; | ||||
| 	/*
 | ||||
| 	 * assume we don't have huge pages in vmalloc space... | ||||
| 	 * So don't worry about THP collapse/split. Called | ||||
| 	 * Only in realmode with MSR_EE = 0, hence won't need irq_save/restore. | ||||
| 	 */ | ||||
| 	p = find_init_mm_pte(addr, NULL); | ||||
| 	if (!p || !pte_present(*p)) | ||||
| 		return NULL; | ||||
| 	addr = (pte_pfn(*p) << PAGE_SHIFT) | (addr & ~PAGE_MASK); | ||||
| 	return __va(addr); | ||||
| 	return __va(ppc_find_vmap_phys((unsigned long)addr)); | ||||
| } | ||||
| 
 | ||||
| /* Return 1 if we need to do a global tlbie, 0 if we can use tlbiel */ | ||||
|  |  | |||
|  | @ -20,6 +20,7 @@ | |||
| #include <asm/machdep.h> | ||||
| #include <asm/rtas.h> | ||||
| #include <asm/kasan.h> | ||||
| #include <asm/sparsemem.h> | ||||
| #include <asm/svm.h> | ||||
| 
 | ||||
| #include <mm/mmu_decl.h> | ||||
|  |  | |||
|  | @ -2254,7 +2254,7 @@ unsigned long perf_instruction_pointer(struct pt_regs *regs) | |||
| 	bool use_siar = regs_use_siar(regs); | ||||
| 	unsigned long siar = mfspr(SPRN_SIAR); | ||||
| 
 | ||||
| 	if (ppmu->flags & PPMU_P10_DD1) { | ||||
| 	if (ppmu && (ppmu->flags & PPMU_P10_DD1)) { | ||||
| 		if (siar) | ||||
| 			return siar; | ||||
| 		else | ||||
|  |  | |||
|  | @ -61,11 +61,11 @@ config RISCV | |||
| 	select GENERIC_TIME_VSYSCALL if MMU && 64BIT | ||||
| 	select HANDLE_DOMAIN_IRQ | ||||
| 	select HAVE_ARCH_AUDITSYSCALL | ||||
| 	select HAVE_ARCH_JUMP_LABEL | ||||
| 	select HAVE_ARCH_JUMP_LABEL_RELATIVE | ||||
| 	select HAVE_ARCH_JUMP_LABEL if !XIP_KERNEL | ||||
| 	select HAVE_ARCH_JUMP_LABEL_RELATIVE if !XIP_KERNEL | ||||
| 	select HAVE_ARCH_KASAN if MMU && 64BIT | ||||
| 	select HAVE_ARCH_KASAN_VMALLOC if MMU && 64BIT | ||||
| 	select HAVE_ARCH_KGDB | ||||
| 	select HAVE_ARCH_KGDB if !XIP_KERNEL | ||||
| 	select HAVE_ARCH_KGDB_QXFER_PKT | ||||
| 	select HAVE_ARCH_MMAP_RND_BITS if MMU | ||||
| 	select HAVE_ARCH_SECCOMP_FILTER | ||||
|  | @ -80,9 +80,9 @@ config RISCV | |||
| 	select HAVE_GCC_PLUGINS | ||||
| 	select HAVE_GENERIC_VDSO if MMU && 64BIT | ||||
| 	select HAVE_IRQ_TIME_ACCOUNTING | ||||
| 	select HAVE_KPROBES | ||||
| 	select HAVE_KPROBES_ON_FTRACE | ||||
| 	select HAVE_KRETPROBES | ||||
| 	select HAVE_KPROBES if !XIP_KERNEL | ||||
| 	select HAVE_KPROBES_ON_FTRACE if !XIP_KERNEL | ||||
| 	select HAVE_KRETPROBES if !XIP_KERNEL | ||||
| 	select HAVE_PCI | ||||
| 	select HAVE_PERF_EVENTS | ||||
| 	select HAVE_PERF_REGS | ||||
|  | @ -231,11 +231,11 @@ config ARCH_RV64I | |||
| 	bool "RV64I" | ||||
| 	select 64BIT | ||||
| 	select ARCH_SUPPORTS_INT128 if CC_HAS_INT128 && GCC_VERSION >= 50000 | ||||
| 	select HAVE_DYNAMIC_FTRACE if MMU && $(cc-option,-fpatchable-function-entry=8) | ||||
| 	select HAVE_DYNAMIC_FTRACE if !XIP_KERNEL && MMU && $(cc-option,-fpatchable-function-entry=8) | ||||
| 	select HAVE_DYNAMIC_FTRACE_WITH_REGS if HAVE_DYNAMIC_FTRACE | ||||
| 	select HAVE_FTRACE_MCOUNT_RECORD | ||||
| 	select HAVE_FTRACE_MCOUNT_RECORD if !XIP_KERNEL | ||||
| 	select HAVE_FUNCTION_GRAPH_TRACER | ||||
| 	select HAVE_FUNCTION_TRACER | ||||
| 	select HAVE_FUNCTION_TRACER if !XIP_KERNEL | ||||
| 	select SWIOTLB if MMU | ||||
| 
 | ||||
| endchoice | ||||
|  |  | |||
|  | @ -14,6 +14,7 @@ config SOC_SIFIVE | |||
| 	select CLK_SIFIVE | ||||
| 	select CLK_SIFIVE_PRCI | ||||
| 	select SIFIVE_PLIC | ||||
| 	select RISCV_ERRATA_ALTERNATIVE | ||||
| 	select ERRATA_SIFIVE | ||||
| 	help | ||||
| 	  This enables support for SiFive SoC platform hardware. | ||||
|  |  | |||
|  | @ -16,7 +16,7 @@ ifeq ($(CONFIG_DYNAMIC_FTRACE),y) | |||
| 	CC_FLAGS_FTRACE := -fpatchable-function-entry=8 | ||||
| endif | ||||
| 
 | ||||
| ifeq ($(CONFIG_64BIT)$(CONFIG_CMODEL_MEDLOW),yy) | ||||
| ifeq ($(CONFIG_CMODEL_MEDLOW),y) | ||||
| KBUILD_CFLAGS_MODULE += -mcmodel=medany | ||||
| endif | ||||
| 
 | ||||
|  | @ -38,6 +38,15 @@ else | |||
| 	KBUILD_LDFLAGS += -melf32lriscv | ||||
| endif | ||||
| 
 | ||||
| ifeq ($(CONFIG_LD_IS_LLD),y) | ||||
| 	KBUILD_CFLAGS += -mno-relax | ||||
| 	KBUILD_AFLAGS += -mno-relax | ||||
| ifneq ($(LLVM_IAS),1) | ||||
| 	KBUILD_CFLAGS += -Wa,-mno-relax | ||||
| 	KBUILD_AFLAGS += -Wa,-mno-relax | ||||
| endif | ||||
| endif | ||||
| 
 | ||||
| # ISA string setting
 | ||||
| riscv-march-$(CONFIG_ARCH_RV32I)	:= rv32ima | ||||
| riscv-march-$(CONFIG_ARCH_RV64I)	:= rv64ima | ||||
|  |  | |||
|  | @ -1,2 +1,3 @@ | |||
| # SPDX-License-Identifier: GPL-2.0
 | ||||
| dtb-$(CONFIG_SOC_MICROCHIP_POLARFIRE) += microchip-mpfs-icicle-kit.dtb | ||||
| obj-$(CONFIG_BUILTIN_DTB) += $(addsuffix .o, $(dtb-y)) | ||||
|  |  | |||
|  | @ -1,3 +1,4 @@ | |||
| # SPDX-License-Identifier: GPL-2.0
 | ||||
| dtb-$(CONFIG_SOC_SIFIVE) += hifive-unleashed-a00.dtb \
 | ||||
| 			    hifive-unmatched-a00.dtb | ||||
| obj-$(CONFIG_BUILTIN_DTB) += $(addsuffix .o, $(dtb-y)) | ||||
|  |  | |||
|  | @ -273,7 +273,7 @@ | |||
| 			cache-size = <2097152>; | ||||
| 			cache-unified; | ||||
| 			interrupt-parent = <&plic0>; | ||||
| 			interrupts = <19 20 21 22>; | ||||
| 			interrupts = <19 21 22 20>; | ||||
| 			reg = <0x0 0x2010000 0x0 0x1000>; | ||||
| 		}; | ||||
| 		gpio: gpio@10060000 { | ||||
|  |  | |||
|  | @ -1,2 +1,2 @@ | |||
| obj-y += errata_cip_453.o | ||||
| obj-$(CONFIG_ERRATA_SIFIVE_CIP_453) += errata_cip_453.o | ||||
| obj-y += errata.o | ||||
|  |  | |||
|  | @ -51,7 +51,7 @@ | |||
| 	REG_ASM " " newlen "\n" \ | ||||
| 	".word " errata_id "\n" | ||||
| 
 | ||||
| #define ALT_NEW_CONSTENT(vendor_id, errata_id, enable, new_c) \ | ||||
| #define ALT_NEW_CONTENT(vendor_id, errata_id, enable, new_c) \ | ||||
| 	".if " __stringify(enable) " == 1\n"				\ | ||||
| 	".pushsection .alternative, \"a\"\n"				\ | ||||
| 	ALT_ENTRY("886b", "888f", __stringify(vendor_id), __stringify(errata_id), "889f - 888f") \ | ||||
|  | @ -69,7 +69,7 @@ | |||
| 	"886 :\n"	\ | ||||
| 	old_c "\n"	\ | ||||
| 	"887 :\n"	\ | ||||
| 	ALT_NEW_CONSTENT(vendor_id, errata_id, enable, new_c) | ||||
| 	ALT_NEW_CONTENT(vendor_id, errata_id, enable, new_c) | ||||
| 
 | ||||
| #define _ALTERNATIVE_CFG(old_c, new_c, vendor_id, errata_id, CONFIG_k)	\ | ||||
| 	__ALTERNATIVE_CFG(old_c, new_c, vendor_id, errata_id, IS_ENABLED(CONFIG_k)) | ||||
|  |  | |||
|  | @ -30,9 +30,8 @@ | |||
| 
 | ||||
| #define BPF_JIT_REGION_SIZE	(SZ_128M) | ||||
| #ifdef CONFIG_64BIT | ||||
| /* KASLR should leave at least 128MB for BPF after the kernel */ | ||||
| #define BPF_JIT_REGION_START	PFN_ALIGN((unsigned long)&_end) | ||||
| #define BPF_JIT_REGION_END	(BPF_JIT_REGION_START + BPF_JIT_REGION_SIZE) | ||||
| #define BPF_JIT_REGION_START	(BPF_JIT_REGION_END - BPF_JIT_REGION_SIZE) | ||||
| #define BPF_JIT_REGION_END	(MODULES_END) | ||||
| #else | ||||
| #define BPF_JIT_REGION_START	(PAGE_OFFSET - BPF_JIT_REGION_SIZE) | ||||
| #define BPF_JIT_REGION_END	(VMALLOC_END) | ||||
|  |  | |||
|  | @ -231,13 +231,13 @@ static void __init init_resources(void) | |||
| 
 | ||||
| 	/* Clean-up any unused pre-allocated resources */ | ||||
| 	mem_res_sz = (num_resources - res_idx + 1) * sizeof(*mem_res); | ||||
| 	memblock_free((phys_addr_t) mem_res, mem_res_sz); | ||||
| 	memblock_free(__pa(mem_res), mem_res_sz); | ||||
| 	return; | ||||
| 
 | ||||
|  error: | ||||
| 	/* Better an empty resource tree than an inconsistent one */ | ||||
| 	release_child_resources(&iomem_resource); | ||||
| 	memblock_free((phys_addr_t) mem_res, mem_res_sz); | ||||
| 	memblock_free(__pa(mem_res), mem_res_sz); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -86,8 +86,13 @@ static void do_trap_error(struct pt_regs *regs, int signo, int code, | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| #if defined (CONFIG_XIP_KERNEL) && defined (CONFIG_RISCV_ERRATA_ALTERNATIVE) | ||||
| #define __trap_section		__section(".xip.traps") | ||||
| #else | ||||
| #define __trap_section | ||||
| #endif | ||||
| #define DO_ERROR_INFO(name, signo, code, str)				\ | ||||
| asmlinkage __visible void name(struct pt_regs *regs)			\ | ||||
| asmlinkage __visible __trap_section void name(struct pt_regs *regs)	\ | ||||
| {									\ | ||||
| 	do_trap_error(regs, signo, code, regs->epc, "Oops - " str);	\ | ||||
| } | ||||
|  | @ -111,7 +116,7 @@ DO_ERROR_INFO(do_trap_store_misaligned, | |||
| int handle_misaligned_load(struct pt_regs *regs); | ||||
| int handle_misaligned_store(struct pt_regs *regs); | ||||
| 
 | ||||
| asmlinkage void do_trap_load_misaligned(struct pt_regs *regs) | ||||
| asmlinkage void __trap_section do_trap_load_misaligned(struct pt_regs *regs) | ||||
| { | ||||
| 	if (!handle_misaligned_load(regs)) | ||||
| 		return; | ||||
|  | @ -119,7 +124,7 @@ asmlinkage void do_trap_load_misaligned(struct pt_regs *regs) | |||
| 		      "Oops - load address misaligned"); | ||||
| } | ||||
| 
 | ||||
| asmlinkage void do_trap_store_misaligned(struct pt_regs *regs) | ||||
| asmlinkage void __trap_section do_trap_store_misaligned(struct pt_regs *regs) | ||||
| { | ||||
| 	if (!handle_misaligned_store(regs)) | ||||
| 		return; | ||||
|  | @ -146,7 +151,7 @@ static inline unsigned long get_break_insn_length(unsigned long pc) | |||
| 	return GET_INSN_LENGTH(insn); | ||||
| } | ||||
| 
 | ||||
| asmlinkage __visible void do_trap_break(struct pt_regs *regs) | ||||
| asmlinkage __visible __trap_section void do_trap_break(struct pt_regs *regs) | ||||
| { | ||||
| #ifdef CONFIG_KPROBES | ||||
| 	if (kprobe_single_step_handler(regs)) | ||||
|  |  | |||
|  | @ -99,9 +99,22 @@ SECTIONS | |||
| 	} | ||||
| 	PERCPU_SECTION(L1_CACHE_BYTES) | ||||
| 
 | ||||
| 	. = ALIGN(PAGE_SIZE);
 | ||||
| 	. = ALIGN(8);
 | ||||
| 	.alternative : { | ||||
| 		__alt_start = .;
 | ||||
| 		*(.alternative) | ||||
| 		__alt_end = .;
 | ||||
| 	} | ||||
| 	__init_end = .;
 | ||||
| 
 | ||||
| 	. = ALIGN(16);
 | ||||
| 	.xip.traps : { | ||||
| 		__xip_traps_start = .;
 | ||||
| 		*(.xip.traps) | ||||
| 		__xip_traps_end = .;
 | ||||
| 	} | ||||
| 
 | ||||
| 	. = ALIGN(PAGE_SIZE);
 | ||||
| 	.sdata : { | ||||
| 		__global_pointer$ = . + 0x800;
 | ||||
| 		*(.sdata*) | ||||
|  |  | |||
|  | @ -746,14 +746,18 @@ void __init protect_kernel_text_data(void) | |||
| 	unsigned long init_data_start = (unsigned long)__init_data_begin; | ||||
| 	unsigned long rodata_start = (unsigned long)__start_rodata; | ||||
| 	unsigned long data_start = (unsigned long)_data; | ||||
| 	unsigned long max_low = (unsigned long)(__va(PFN_PHYS(max_low_pfn))); | ||||
| #if defined(CONFIG_64BIT) && defined(CONFIG_MMU) | ||||
| 	unsigned long end_va = kernel_virt_addr + load_sz; | ||||
| #else | ||||
| 	unsigned long end_va = (unsigned long)(__va(PFN_PHYS(max_low_pfn))); | ||||
| #endif | ||||
| 
 | ||||
| 	set_memory_ro(text_start, (init_text_start - text_start) >> PAGE_SHIFT); | ||||
| 	set_memory_ro(init_text_start, (init_data_start - init_text_start) >> PAGE_SHIFT); | ||||
| 	set_memory_nx(init_data_start, (rodata_start - init_data_start) >> PAGE_SHIFT); | ||||
| 	/* rodata section is marked readonly in mark_rodata_ro */ | ||||
| 	set_memory_nx(rodata_start, (data_start - rodata_start) >> PAGE_SHIFT); | ||||
| 	set_memory_nx(data_start, (max_low - data_start) >> PAGE_SHIFT); | ||||
| 	set_memory_nx(data_start, (end_va - data_start) >> PAGE_SHIFT); | ||||
| } | ||||
| 
 | ||||
| void mark_rodata_ro(void) | ||||
|  |  | |||
|  | @ -169,7 +169,7 @@ static void __init kasan_shallow_populate(void *start, void *end) | |||
| 
 | ||||
| void __init kasan_init(void) | ||||
| { | ||||
| 	phys_addr_t _start, _end; | ||||
| 	phys_addr_t p_start, p_end; | ||||
| 	u64 i; | ||||
| 
 | ||||
| 	/*
 | ||||
|  | @ -189,9 +189,9 @@ void __init kasan_init(void) | |||
| 			(void *)kasan_mem_to_shadow((void *)VMALLOC_END)); | ||||
| 
 | ||||
| 	/* Populate the linear mapping */ | ||||
| 	for_each_mem_range(i, &_start, &_end) { | ||||
| 		void *start = (void *)__va(_start); | ||||
| 		void *end = (void *)__va(_end); | ||||
| 	for_each_mem_range(i, &p_start, &p_end) { | ||||
| 		void *start = (void *)__va(p_start); | ||||
| 		void *end = (void *)__va(p_end); | ||||
| 
 | ||||
| 		if (start >= end) | ||||
| 			break; | ||||
|  | @ -201,7 +201,7 @@ void __init kasan_init(void) | |||
| 
 | ||||
| 	/* Populate kernel, BPF, modules mapping */ | ||||
| 	kasan_populate(kasan_mem_to_shadow((const void *)MODULES_VADDR), | ||||
| 		       kasan_mem_to_shadow((const void *)BPF_JIT_REGION_END)); | ||||
| 		       kasan_mem_to_shadow((const void *)MODULES_VADDR + SZ_2G)); | ||||
| 
 | ||||
| 	for (i = 0; i < PTRS_PER_PTE; i++) | ||||
| 		set_pte(&kasan_early_shadow_pte[i], | ||||
|  |  | |||
|  | @ -651,9 +651,9 @@ ENDPROC(stack_overflow) | |||
| .Lcleanup_sie_mcck: | ||||
| 	larl	%r13,.Lsie_entry | ||||
| 	slgr	%r9,%r13 | ||||
| 	larl	%r13,.Lsie_skip | ||||
| 	lghi	%r13,.Lsie_skip - .Lsie_entry | ||||
| 	clgr	%r9,%r13 | ||||
| 	jh	.Lcleanup_sie_int | ||||
| 	jhe	.Lcleanup_sie_int | ||||
| 	oi	__LC_CPU_FLAGS+7, _CIF_MCCK_GUEST | ||||
| .Lcleanup_sie_int: | ||||
| 	BPENTER	__SF_SIE_FLAGS(%r15),(_TIF_ISOLATE_BP|_TIF_ISOLATE_BP_GUEST) | ||||
|  |  | |||
|  | @ -200,8 +200,9 @@ endif | |||
| KBUILD_LDFLAGS += -m elf_$(UTS_MACHINE) | ||||
| 
 | ||||
| ifdef CONFIG_LTO_CLANG | ||||
| KBUILD_LDFLAGS	+= -plugin-opt=-code-model=kernel \
 | ||||
| 		   -plugin-opt=-stack-alignment=$(if $(CONFIG_X86_32),4,8) | ||||
| ifeq ($(shell test $(CONFIG_LLD_VERSION) -lt 130000; echo $$?),0) | ||||
| KBUILD_LDFLAGS	+= -plugin-opt=-stack-alignment=$(if $(CONFIG_X86_32),4,8) | ||||
| endif | ||||
| endif | ||||
| 
 | ||||
| ifdef CONFIG_X86_NEED_RELOCS | ||||
|  |  | |||
|  | @ -1406,6 +1406,8 @@ static int snbep_pci2phy_map_init(int devid, int nodeid_loc, int idmap_loc, bool | |||
| 						die_id = i; | ||||
| 					else | ||||
| 						die_id = topology_phys_to_logical_pkg(i); | ||||
| 					if (die_id < 0) | ||||
| 						die_id = -ENODEV; | ||||
| 					map->pbus_to_dieid[bus] = die_id; | ||||
| 					break; | ||||
| 				} | ||||
|  | @ -1452,14 +1454,14 @@ static int snbep_pci2phy_map_init(int devid, int nodeid_loc, int idmap_loc, bool | |||
| 			i = -1; | ||||
| 			if (reverse) { | ||||
| 				for (bus = 255; bus >= 0; bus--) { | ||||
| 					if (map->pbus_to_dieid[bus] >= 0) | ||||
| 					if (map->pbus_to_dieid[bus] != -1) | ||||
| 						i = map->pbus_to_dieid[bus]; | ||||
| 					else | ||||
| 						map->pbus_to_dieid[bus] = i; | ||||
| 				} | ||||
| 			} else { | ||||
| 				for (bus = 0; bus <= 255; bus++) { | ||||
| 					if (map->pbus_to_dieid[bus] >= 0) | ||||
| 					if (map->pbus_to_dieid[bus] != -1) | ||||
| 						i = map->pbus_to_dieid[bus]; | ||||
| 					else | ||||
| 						map->pbus_to_dieid[bus] = i; | ||||
|  | @ -5097,9 +5099,10 @@ static struct intel_uncore_type icx_uncore_m2m = { | |||
| 	.perf_ctr	= SNR_M2M_PCI_PMON_CTR0, | ||||
| 	.event_ctl	= SNR_M2M_PCI_PMON_CTL0, | ||||
| 	.event_mask	= SNBEP_PMON_RAW_EVENT_MASK, | ||||
| 	.event_mask_ext	= SNR_M2M_PCI_PMON_UMASK_EXT, | ||||
| 	.box_ctl	= SNR_M2M_PCI_PMON_BOX_CTL, | ||||
| 	.ops		= &snr_m2m_uncore_pci_ops, | ||||
| 	.format_group	= &skx_uncore_format_group, | ||||
| 	.format_group	= &snr_m2m_uncore_format_group, | ||||
| }; | ||||
| 
 | ||||
| static struct attribute *icx_upi_uncore_formats_attr[] = { | ||||
|  |  | |||
|  | @ -174,6 +174,7 @@ static inline int apic_is_clustered_box(void) | |||
| extern int setup_APIC_eilvt(u8 lvt_off, u8 vector, u8 msg_type, u8 mask); | ||||
| extern void lapic_assign_system_vectors(void); | ||||
| extern void lapic_assign_legacy_vector(unsigned int isairq, bool replace); | ||||
| extern void lapic_update_legacy_vectors(void); | ||||
| extern void lapic_online(void); | ||||
| extern void lapic_offline(void); | ||||
| extern bool apic_needs_pit(void); | ||||
|  |  | |||
|  | @ -56,11 +56,8 @@ | |||
| # define DISABLE_PTI		(1 << (X86_FEATURE_PTI & 31)) | ||||
| #endif | ||||
| 
 | ||||
| #ifdef CONFIG_IOMMU_SUPPORT | ||||
| # define DISABLE_ENQCMD	0 | ||||
| #else | ||||
| # define DISABLE_ENQCMD (1 << (X86_FEATURE_ENQCMD & 31)) | ||||
| #endif | ||||
| /* Force disable because it's broken beyond repair */ | ||||
| #define DISABLE_ENQCMD		(1 << (X86_FEATURE_ENQCMD & 31)) | ||||
| 
 | ||||
| #ifdef CONFIG_X86_SGX | ||||
| # define DISABLE_SGX	0 | ||||
|  |  | |||
|  | @ -106,10 +106,6 @@ extern int cpu_has_xfeatures(u64 xfeatures_mask, const char **feature_name); | |||
|  */ | ||||
| #define PASID_DISABLED	0 | ||||
| 
 | ||||
| #ifdef CONFIG_IOMMU_SUPPORT | ||||
| /* Update current's PASID MSR/state by mm's PASID. */ | ||||
| void update_pasid(void); | ||||
| #else | ||||
| static inline void update_pasid(void) { } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _ASM_X86_FPU_API_H */ | ||||
|  |  | |||
|  | @ -578,19 +578,19 @@ static inline void switch_fpu_finish(struct fpu *new_fpu) | |||
| 	 * PKRU state is switched eagerly because it needs to be valid before we | ||||
| 	 * return to userland e.g. for a copy_to_user() operation. | ||||
| 	 */ | ||||
| 	if (current->mm) { | ||||
| 	if (!(current->flags & PF_KTHREAD)) { | ||||
| 		/*
 | ||||
| 		 * If the PKRU bit in xsave.header.xfeatures is not set, | ||||
| 		 * then the PKRU component was in init state, which means | ||||
| 		 * XRSTOR will set PKRU to 0. If the bit is not set then | ||||
| 		 * get_xsave_addr() will return NULL because the PKRU value | ||||
| 		 * in memory is not valid. This means pkru_val has to be | ||||
| 		 * set to 0 and not to init_pkru_value. | ||||
| 		 */ | ||||
| 		pk = get_xsave_addr(&new_fpu->state.xsave, XFEATURE_PKRU); | ||||
| 		if (pk) | ||||
| 			pkru_val = pk->pkru; | ||||
| 		pkru_val = pk ? pk->pkru : 0; | ||||
| 	} | ||||
| 	__write_pkru(pkru_val); | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * Expensive PASID MSR write will be avoided in update_pasid() because | ||||
| 	 * TIF_NEED_FPU_LOAD was set. And the PASID state won't be updated | ||||
| 	 * unless it's different from mm->pasid to reduce overhead. | ||||
| 	 */ | ||||
| 	update_pasid(); | ||||
| } | ||||
| 
 | ||||
| #endif /* _ASM_X86_FPU_INTERNAL_H */ | ||||
|  |  | |||
|  | @ -3,11 +3,13 @@ | |||
| #define _ASM_X86_THERMAL_H | ||||
| 
 | ||||
| #ifdef CONFIG_X86_THERMAL_VECTOR | ||||
| void therm_lvt_init(void); | ||||
| void intel_init_thermal(struct cpuinfo_x86 *c); | ||||
| bool x86_thermal_enabled(void); | ||||
| void intel_thermal_interrupt(void); | ||||
| #else | ||||
| static inline void intel_init_thermal(struct cpuinfo_x86 *c) { } | ||||
| static inline void therm_lvt_init(void)				{ } | ||||
| static inline void intel_init_thermal(struct cpuinfo_x86 *c)	{ } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _ASM_X86_THERMAL_H */ | ||||
|  |  | |||
|  | @ -182,42 +182,70 @@ done: | |||
| 		n_dspl, (unsigned long)orig_insn + n_dspl + repl_len); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * optimize_nops_range() - Optimize a sequence of single byte NOPs (0x90) | ||||
|  * | ||||
|  * @instr: instruction byte stream | ||||
|  * @instrlen: length of the above | ||||
|  * @off: offset within @instr where the first NOP has been detected | ||||
|  * | ||||
|  * Return: number of NOPs found (and replaced). | ||||
|  */ | ||||
| static __always_inline int optimize_nops_range(u8 *instr, u8 instrlen, int off) | ||||
| { | ||||
| 	unsigned long flags; | ||||
| 	int i = off, nnops; | ||||
| 
 | ||||
| 	while (i < instrlen) { | ||||
| 		if (instr[i] != 0x90) | ||||
| 			break; | ||||
| 
 | ||||
| 		i++; | ||||
| 	} | ||||
| 
 | ||||
| 	nnops = i - off; | ||||
| 
 | ||||
| 	if (nnops <= 1) | ||||
| 		return nnops; | ||||
| 
 | ||||
| 	local_irq_save(flags); | ||||
| 	add_nops(instr + off, nnops); | ||||
| 	local_irq_restore(flags); | ||||
| 
 | ||||
| 	DUMP_BYTES(instr, instrlen, "%px: [%d:%d) optimized NOPs: ", instr, off, i); | ||||
| 
 | ||||
| 	return nnops; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * "noinline" to cause control flow change and thus invalidate I$ and | ||||
|  * cause refetch after modification. | ||||
|  */ | ||||
| static void __init_or_module noinline optimize_nops(struct alt_instr *a, u8 *instr) | ||||
| { | ||||
| 	unsigned long flags; | ||||
| 	struct insn insn; | ||||
| 	int nop, i = 0; | ||||
| 	int i = 0; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * Jump over the non-NOP insns, the remaining bytes must be single-byte | ||||
| 	 * NOPs, optimize them. | ||||
| 	 * Jump over the non-NOP insns and optimize single-byte NOPs into bigger | ||||
| 	 * ones. | ||||
| 	 */ | ||||
| 	for (;;) { | ||||
| 		if (insn_decode_kernel(&insn, &instr[i])) | ||||
| 			return; | ||||
| 
 | ||||
| 		/*
 | ||||
| 		 * See if this and any potentially following NOPs can be | ||||
| 		 * optimized. | ||||
| 		 */ | ||||
| 		if (insn.length == 1 && insn.opcode.bytes[0] == 0x90) | ||||
| 			break; | ||||
| 			i += optimize_nops_range(instr, a->instrlen, i); | ||||
| 		else | ||||
| 			i += insn.length; | ||||
| 
 | ||||
| 		if ((i += insn.length) >= a->instrlen) | ||||
| 		if (i >= a->instrlen) | ||||
| 			return; | ||||
| 	} | ||||
| 
 | ||||
| 	for (nop = i; i < a->instrlen; i++) { | ||||
| 		if (WARN_ONCE(instr[i] != 0x90, "Not a NOP at 0x%px\n", &instr[i])) | ||||
| 			return; | ||||
| 	} | ||||
| 
 | ||||
| 	local_irq_save(flags); | ||||
| 	add_nops(instr + nop, i - nop); | ||||
| 	local_irq_restore(flags); | ||||
| 
 | ||||
| 	DUMP_BYTES(instr, a->instrlen, "%px: [%d:%d) optimized NOPs: ", | ||||
| 		   instr, nop, a->instrlen); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  |  | |||
|  | @ -2604,6 +2604,7 @@ static void __init apic_bsp_setup(bool upmode) | |||
| 	end_local_APIC_setup(); | ||||
| 	irq_remap_enable_fault_handling(); | ||||
| 	setup_IO_APIC(); | ||||
| 	lapic_update_legacy_vectors(); | ||||
| } | ||||
| 
 | ||||
| #ifdef CONFIG_UP_LATE_INIT | ||||
|  |  | |||
|  | @ -738,6 +738,26 @@ void lapic_assign_legacy_vector(unsigned int irq, bool replace) | |||
| 	irq_matrix_assign_system(vector_matrix, ISA_IRQ_VECTOR(irq), replace); | ||||
| } | ||||
| 
 | ||||
| void __init lapic_update_legacy_vectors(void) | ||||
| { | ||||
| 	unsigned int i; | ||||
| 
 | ||||
| 	if (IS_ENABLED(CONFIG_X86_IO_APIC) && nr_ioapics > 0) | ||||
| 		return; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * If the IO/APIC is disabled via config, kernel command line or | ||||
| 	 * lack of enumeration then all legacy interrupts are routed | ||||
| 	 * through the PIC. Make sure that they are marked as legacy | ||||
| 	 * vectors. PIC_CASCADE_IRQ has already been marked in | ||||
| 	 * lapic_assign_system_vectors(). | ||||
| 	 */ | ||||
| 	for (i = 0; i < nr_legacy_irqs(); i++) { | ||||
| 		if (i != PIC_CASCADE_IR) | ||||
| 			lapic_assign_legacy_vector(i, true); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void __init lapic_assign_system_vectors(void) | ||||
| { | ||||
| 	unsigned int i, vector = 0; | ||||
|  |  | |||
|  | @ -63,7 +63,7 @@ static inline unsigned int nmi_perfctr_msr_to_bit(unsigned int msr) | |||
| 		case 15: | ||||
| 			return msr - MSR_P4_BPU_PERFCTR0; | ||||
| 		} | ||||
| 		fallthrough; | ||||
| 		break; | ||||
| 	case X86_VENDOR_ZHAOXIN: | ||||
| 	case X86_VENDOR_CENTAUR: | ||||
| 		return msr - MSR_ARCH_PERFMON_PERFCTR0; | ||||
|  | @ -96,7 +96,7 @@ static inline unsigned int nmi_evntsel_msr_to_bit(unsigned int msr) | |||
| 		case 15: | ||||
| 			return msr - MSR_P4_BSU_ESCR0; | ||||
| 		} | ||||
| 		fallthrough; | ||||
| 		break; | ||||
| 	case X86_VENDOR_ZHAOXIN: | ||||
| 	case X86_VENDOR_CENTAUR: | ||||
| 		return msr - MSR_ARCH_PERFMON_EVENTSEL0; | ||||
|  |  | |||
|  | @ -212,6 +212,7 @@ static int sgx_vepc_release(struct inode *inode, struct file *file) | |||
| 		list_splice_tail(&secs_pages, &zombie_secs_pages); | ||||
| 	mutex_unlock(&zombie_secs_pages_lock); | ||||
| 
 | ||||
| 	xa_destroy(&vepc->page_array); | ||||
| 	kfree(vepc); | ||||
| 
 | ||||
| 	return 0; | ||||
|  |  | |||
|  | @ -307,13 +307,17 @@ static int __fpu__restore_sig(void __user *buf, void __user *buf_fx, int size) | |||
| 		return 0; | ||||
| 	} | ||||
| 
 | ||||
| 	if (!access_ok(buf, size)) | ||||
| 		return -EACCES; | ||||
| 	if (!access_ok(buf, size)) { | ||||
| 		ret = -EACCES; | ||||
| 		goto out; | ||||
| 	} | ||||
| 
 | ||||
| 	if (!static_cpu_has(X86_FEATURE_FPU)) | ||||
| 		return fpregs_soft_set(current, NULL, | ||||
| 				       0, sizeof(struct user_i387_ia32_struct), | ||||
| 				       NULL, buf) != 0; | ||||
| 	if (!static_cpu_has(X86_FEATURE_FPU)) { | ||||
| 		ret = fpregs_soft_set(current, NULL, 0, | ||||
| 				      sizeof(struct user_i387_ia32_struct), | ||||
| 				      NULL, buf); | ||||
| 		goto out; | ||||
| 	} | ||||
| 
 | ||||
| 	if (use_xsave()) { | ||||
| 		struct _fpx_sw_bytes fx_sw_user; | ||||
|  | @ -369,6 +373,25 @@ static int __fpu__restore_sig(void __user *buf, void __user *buf_fx, int size) | |||
| 			fpregs_unlock(); | ||||
| 			return 0; | ||||
| 		} | ||||
| 
 | ||||
| 		/*
 | ||||
| 		 * The above did an FPU restore operation, restricted to | ||||
| 		 * the user portion of the registers, and failed, but the | ||||
| 		 * microcode might have modified the FPU registers | ||||
| 		 * nevertheless. | ||||
| 		 * | ||||
| 		 * If the FPU registers do not belong to current, then | ||||
| 		 * invalidate the FPU register state otherwise the task might | ||||
| 		 * preempt current and return to user space with corrupted | ||||
| 		 * FPU registers. | ||||
| 		 * | ||||
| 		 * In case current owns the FPU registers then no further | ||||
| 		 * action is required. The fixup below will handle it | ||||
| 		 * correctly. | ||||
| 		 */ | ||||
| 		if (test_thread_flag(TIF_NEED_FPU_LOAD)) | ||||
| 			__cpu_invalidate_fpregs_state(); | ||||
| 
 | ||||
| 		fpregs_unlock(); | ||||
| 	} else { | ||||
| 		/*
 | ||||
|  | @ -377,7 +400,7 @@ static int __fpu__restore_sig(void __user *buf, void __user *buf_fx, int size) | |||
| 		 */ | ||||
| 		ret = __copy_from_user(&env, buf, sizeof(env)); | ||||
| 		if (ret) | ||||
| 			goto err_out; | ||||
| 			goto out; | ||||
| 		envp = &env; | ||||
| 	} | ||||
| 
 | ||||
|  | @ -405,16 +428,9 @@ static int __fpu__restore_sig(void __user *buf, void __user *buf_fx, int size) | |||
| 	if (use_xsave() && !fx_only) { | ||||
| 		u64 init_bv = xfeatures_mask_user() & ~user_xfeatures; | ||||
| 
 | ||||
| 		if (using_compacted_format()) { | ||||
| 			ret = copy_user_to_xstate(&fpu->state.xsave, buf_fx); | ||||
| 		} else { | ||||
| 			ret = __copy_from_user(&fpu->state.xsave, buf_fx, state_size); | ||||
| 
 | ||||
| 			if (!ret && state_size > offsetof(struct xregs_state, header)) | ||||
| 				ret = validate_user_xstate_header(&fpu->state.xsave.header); | ||||
| 		} | ||||
| 		ret = copy_user_to_xstate(&fpu->state.xsave, buf_fx); | ||||
| 		if (ret) | ||||
| 			goto err_out; | ||||
| 			goto out; | ||||
| 
 | ||||
| 		sanitize_restored_user_xstate(&fpu->state, envp, user_xfeatures, | ||||
| 					      fx_only); | ||||
|  | @ -434,7 +450,7 @@ static int __fpu__restore_sig(void __user *buf, void __user *buf_fx, int size) | |||
| 		ret = __copy_from_user(&fpu->state.fxsave, buf_fx, state_size); | ||||
| 		if (ret) { | ||||
| 			ret = -EFAULT; | ||||
| 			goto err_out; | ||||
| 			goto out; | ||||
| 		} | ||||
| 
 | ||||
| 		sanitize_restored_user_xstate(&fpu->state, envp, user_xfeatures, | ||||
|  | @ -452,7 +468,7 @@ static int __fpu__restore_sig(void __user *buf, void __user *buf_fx, int size) | |||
| 	} else { | ||||
| 		ret = __copy_from_user(&fpu->state.fsave, buf_fx, state_size); | ||||
| 		if (ret) | ||||
| 			goto err_out; | ||||
| 			goto out; | ||||
| 
 | ||||
| 		fpregs_lock(); | ||||
| 		ret = copy_kernel_to_fregs_err(&fpu->state.fsave); | ||||
|  | @ -463,7 +479,7 @@ static int __fpu__restore_sig(void __user *buf, void __user *buf_fx, int size) | |||
| 		fpregs_deactivate(fpu); | ||||
| 	fpregs_unlock(); | ||||
| 
 | ||||
| err_out: | ||||
| out: | ||||
| 	if (ret) | ||||
| 		fpu__clear_user_states(fpu); | ||||
| 	return ret; | ||||
|  |  | |||
|  | @ -1402,60 +1402,3 @@ int proc_pid_arch_status(struct seq_file *m, struct pid_namespace *ns, | |||
| 	return 0; | ||||
| } | ||||
| #endif /* CONFIG_PROC_PID_ARCH_STATUS */ | ||||
| 
 | ||||
| #ifdef CONFIG_IOMMU_SUPPORT | ||||
| void update_pasid(void) | ||||
| { | ||||
| 	u64 pasid_state; | ||||
| 	u32 pasid; | ||||
| 
 | ||||
| 	if (!cpu_feature_enabled(X86_FEATURE_ENQCMD)) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (!current->mm) | ||||
| 		return; | ||||
| 
 | ||||
| 	pasid = READ_ONCE(current->mm->pasid); | ||||
| 	/* Set the valid bit in the PASID MSR/state only for valid pasid. */ | ||||
| 	pasid_state = pasid == PASID_DISABLED ? | ||||
| 		      pasid : pasid | MSR_IA32_PASID_VALID; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * No need to hold fregs_lock() since the task's fpstate won't | ||||
| 	 * be changed by others (e.g. ptrace) while the task is being | ||||
| 	 * switched to or is in IPI. | ||||
| 	 */ | ||||
| 	if (!test_thread_flag(TIF_NEED_FPU_LOAD)) { | ||||
| 		/* The MSR is active and can be directly updated. */ | ||||
| 		wrmsrl(MSR_IA32_PASID, pasid_state); | ||||
| 	} else { | ||||
| 		struct fpu *fpu = ¤t->thread.fpu; | ||||
| 		struct ia32_pasid_state *ppasid_state; | ||||
| 		struct xregs_state *xsave; | ||||
| 
 | ||||
| 		/*
 | ||||
| 		 * The CPU's xstate registers are not currently active. Just | ||||
| 		 * update the PASID state in the memory buffer here. The | ||||
| 		 * PASID MSR will be loaded when returning to user mode. | ||||
| 		 */ | ||||
| 		xsave = &fpu->state.xsave; | ||||
| 		xsave->header.xfeatures |= XFEATURE_MASK_PASID; | ||||
| 		ppasid_state = get_xsave_addr(xsave, XFEATURE_PASID); | ||||
| 		/*
 | ||||
| 		 * Since XFEATURE_MASK_PASID is set in xfeatures, ppasid_state | ||||
| 		 * won't be NULL and no need to check its value. | ||||
| 		 * | ||||
| 		 * Only update the task's PASID state when it's different | ||||
| 		 * from the mm's pasid. | ||||
| 		 */ | ||||
| 		if (ppasid_state->pasid != pasid_state) { | ||||
| 			/*
 | ||||
| 			 * Invalid fpregs so that state restoring will pick up | ||||
| 			 * the PASID state. | ||||
| 			 */ | ||||
| 			__fpu_invalidate_fpregs_state(fpu); | ||||
| 			ppasid_state->pasid = pasid_state; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| #endif /* CONFIG_IOMMU_SUPPORT */ | ||||
|  |  | |||
|  | @ -44,6 +44,7 @@ | |||
| #include <asm/pci-direct.h> | ||||
| #include <asm/prom.h> | ||||
| #include <asm/proto.h> | ||||
| #include <asm/thermal.h> | ||||
| #include <asm/unwind.h> | ||||
| #include <asm/vsyscall.h> | ||||
| #include <linux/vmalloc.h> | ||||
|  | @ -637,11 +638,11 @@ static void __init trim_snb_memory(void) | |||
| 	 * them from accessing certain memory ranges, namely anything below | ||||
| 	 * 1M and in the pages listed in bad_pages[] above. | ||||
| 	 * | ||||
| 	 * To avoid these pages being ever accessed by SNB gfx devices | ||||
| 	 * reserve all memory below the 1 MB mark and bad_pages that have | ||||
| 	 * not already been reserved at boot time. | ||||
| 	 * To avoid these pages being ever accessed by SNB gfx devices reserve | ||||
| 	 * bad_pages that have not already been reserved at boot time. | ||||
| 	 * All memory below the 1 MB mark is anyway reserved later during | ||||
| 	 * setup_arch(), so there is no need to reserve it here. | ||||
| 	 */ | ||||
| 	memblock_reserve(0, 1<<20); | ||||
| 
 | ||||
| 	for (i = 0; i < ARRAY_SIZE(bad_pages); i++) { | ||||
| 		if (memblock_reserve(bad_pages[i], PAGE_SIZE)) | ||||
|  | @ -733,14 +734,14 @@ static void __init early_reserve_memory(void) | |||
| 	 * The first 4Kb of memory is a BIOS owned area, but generally it is | ||||
| 	 * not listed as such in the E820 table. | ||||
| 	 * | ||||
| 	 * Reserve the first memory page and typically some additional | ||||
| 	 * memory (64KiB by default) since some BIOSes are known to corrupt | ||||
| 	 * low memory. See the Kconfig help text for X86_RESERVE_LOW. | ||||
| 	 * Reserve the first 64K of memory since some BIOSes are known to | ||||
| 	 * corrupt low memory. After the real mode trampoline is allocated the | ||||
| 	 * rest of the memory below 640k is reserved. | ||||
| 	 * | ||||
| 	 * In addition, make sure page 0 is always reserved because on | ||||
| 	 * systems with L1TF its contents can be leaked to user processes. | ||||
| 	 */ | ||||
| 	memblock_reserve(0, ALIGN(reserve_low, PAGE_SIZE)); | ||||
| 	memblock_reserve(0, SZ_64K); | ||||
| 
 | ||||
| 	early_reserve_initrd(); | ||||
| 
 | ||||
|  | @ -751,6 +752,7 @@ static void __init early_reserve_memory(void) | |||
| 
 | ||||
| 	reserve_ibft_region(); | ||||
| 	reserve_bios_regions(); | ||||
| 	trim_snb_memory(); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  | @ -1081,14 +1083,20 @@ void __init setup_arch(char **cmdline_p) | |||
| 			(max_pfn_mapped<<PAGE_SHIFT) - 1); | ||||
| #endif | ||||
| 
 | ||||
| 	reserve_real_mode(); | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * Reserving memory causing GPU hangs on Sandy Bridge integrated | ||||
| 	 * graphics devices should be done after we allocated memory under | ||||
| 	 * 1M for the real mode trampoline. | ||||
| 	 * Find free memory for the real mode trampoline and place it | ||||
| 	 * there. | ||||
| 	 * If there is not enough free memory under 1M, on EFI-enabled | ||||
| 	 * systems there will be additional attempt to reclaim the memory | ||||
| 	 * for the real mode trampoline at efi_free_boot_services(). | ||||
| 	 * | ||||
| 	 * Unconditionally reserve the entire first 1M of RAM because | ||||
| 	 * BIOSes are know to corrupt low memory and several | ||||
| 	 * hundred kilobytes are not worth complex detection what memory gets | ||||
| 	 * clobbered. Moreover, on machines with SandyBridge graphics or in | ||||
| 	 * setups that use crashkernel the entire 1M is reserved anyway. | ||||
| 	 */ | ||||
| 	trim_snb_memory(); | ||||
| 	reserve_real_mode(); | ||||
| 
 | ||||
| 	init_mem_mapping(); | ||||
| 
 | ||||
|  | @ -1226,6 +1234,14 @@ void __init setup_arch(char **cmdline_p) | |||
| 
 | ||||
| 	x86_init.timers.wallclock_init(); | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * This needs to run before setup_local_APIC() which soft-disables the | ||||
| 	 * local APIC temporarily and that masks the thermal LVT interrupt, | ||||
| 	 * leading to softlockups on machines which have configured SMI | ||||
| 	 * interrupt delivery. | ||||
| 	 */ | ||||
| 	therm_lvt_init(); | ||||
| 
 | ||||
| 	mcheck_init(); | ||||
| 
 | ||||
| 	register_refined_jiffies(CLOCK_TICK_RATE); | ||||
|  |  | |||
|  | @ -836,8 +836,8 @@ __bad_area_nosemaphore(struct pt_regs *regs, unsigned long error_code, | |||
| 
 | ||||
| 	if (si_code == SEGV_PKUERR) | ||||
| 		force_sig_pkuerr((void __user *)address, pkey); | ||||
| 
 | ||||
| 	force_sig_fault(SIGSEGV, si_code, (void __user *)address); | ||||
| 	else | ||||
| 		force_sig_fault(SIGSEGV, si_code, (void __user *)address); | ||||
| 
 | ||||
| 	local_irq_disable(); | ||||
| } | ||||
|  |  | |||
|  | @ -118,7 +118,9 @@ static void __ioremap_check_other(resource_size_t addr, struct ioremap_desc *des | |||
| 	if (!IS_ENABLED(CONFIG_EFI)) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (efi_mem_type(addr) == EFI_RUNTIME_SERVICES_DATA) | ||||
| 	if (efi_mem_type(addr) == EFI_RUNTIME_SERVICES_DATA || | ||||
| 	    (efi_mem_type(addr) == EFI_BOOT_SERVICES_DATA && | ||||
| 	     efi_mem_attributes(addr) & EFI_MEMORY_RUNTIME)) | ||||
| 		desc->flags |= IORES_MAP_ENCRYPTED; | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -504,10 +504,6 @@ void __init sme_enable(struct boot_params *bp) | |||
| #define AMD_SME_BIT	BIT(0) | ||||
| #define AMD_SEV_BIT	BIT(1) | ||||
| 
 | ||||
| 	/* Check the SEV MSR whether SEV or SME is enabled */ | ||||
| 	sev_status   = __rdmsr(MSR_AMD64_SEV); | ||||
| 	feature_mask = (sev_status & MSR_AMD64_SEV_ENABLED) ? AMD_SEV_BIT : AMD_SME_BIT; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * Check for the SME/SEV feature: | ||||
| 	 *   CPUID Fn8000_001F[EAX] | ||||
|  | @ -519,11 +515,16 @@ void __init sme_enable(struct boot_params *bp) | |||
| 	eax = 0x8000001f; | ||||
| 	ecx = 0; | ||||
| 	native_cpuid(&eax, &ebx, &ecx, &edx); | ||||
| 	if (!(eax & feature_mask)) | ||||
| 	/* Check whether SEV or SME is supported */ | ||||
| 	if (!(eax & (AMD_SEV_BIT | AMD_SME_BIT))) | ||||
| 		return; | ||||
| 
 | ||||
| 	me_mask = 1UL << (ebx & 0x3f); | ||||
| 
 | ||||
| 	/* Check the SEV MSR whether SEV or SME is enabled */ | ||||
| 	sev_status   = __rdmsr(MSR_AMD64_SEV); | ||||
| 	feature_mask = (sev_status & MSR_AMD64_SEV_ENABLED) ? AMD_SEV_BIT : AMD_SME_BIT; | ||||
| 
 | ||||
| 	/* Check if memory encryption is enabled */ | ||||
| 	if (feature_mask == AMD_SME_BIT) { | ||||
| 		/*
 | ||||
|  |  | |||
|  | @ -254,7 +254,13 @@ int __init numa_cleanup_meminfo(struct numa_meminfo *mi) | |||
| 
 | ||||
| 		/* make sure all non-reserved blocks are inside the limits */ | ||||
| 		bi->start = max(bi->start, low); | ||||
| 		bi->end = min(bi->end, high); | ||||
| 
 | ||||
| 		/* preserve info for non-RAM areas above 'max_pfn': */ | ||||
| 		if (bi->end > high) { | ||||
| 			numa_add_memblk_to(bi->nid, high, bi->end, | ||||
| 					   &numa_reserved_meminfo); | ||||
| 			bi->end = high; | ||||
| 		} | ||||
| 
 | ||||
| 		/* and there's no empty block */ | ||||
| 		if (bi->start >= bi->end) | ||||
|  |  | |||
|  | @ -779,4 +779,48 @@ DECLARE_PCI_FIXUP_RESUME(PCI_VENDOR_ID_AMD, 0x1571, pci_amd_enable_64bit_bar); | |||
| DECLARE_PCI_FIXUP_RESUME(PCI_VENDOR_ID_AMD, 0x15b1, pci_amd_enable_64bit_bar); | ||||
| DECLARE_PCI_FIXUP_RESUME(PCI_VENDOR_ID_AMD, 0x1601, pci_amd_enable_64bit_bar); | ||||
| 
 | ||||
| #define RS690_LOWER_TOP_OF_DRAM2	0x30 | ||||
| #define RS690_LOWER_TOP_OF_DRAM2_VALID	0x1 | ||||
| #define RS690_UPPER_TOP_OF_DRAM2	0x31 | ||||
| #define RS690_HTIU_NB_INDEX		0xA8 | ||||
| #define RS690_HTIU_NB_INDEX_WR_ENABLE	0x100 | ||||
| #define RS690_HTIU_NB_DATA		0xAC | ||||
| 
 | ||||
| /*
 | ||||
|  * Some BIOS implementations support RAM above 4GB, but do not configure the | ||||
|  * PCI host to respond to bus master accesses for these addresses. These | ||||
|  * implementations set the TOP_OF_DRAM_SLOT1 register correctly, so PCI DMA | ||||
|  * works as expected for addresses below 4GB. | ||||
|  * | ||||
|  * Reference: "AMD RS690 ASIC Family Register Reference Guide" (pg. 2-57) | ||||
|  * https://www.amd.com/system/files/TechDocs/43372_rs690_rrg_3.00o.pdf
 | ||||
|  */ | ||||
| static void rs690_fix_64bit_dma(struct pci_dev *pdev) | ||||
| { | ||||
| 	u32 val = 0; | ||||
| 	phys_addr_t top_of_dram = __pa(high_memory - 1) + 1; | ||||
| 
 | ||||
| 	if (top_of_dram <= (1ULL << 32)) | ||||
| 		return; | ||||
| 
 | ||||
| 	pci_write_config_dword(pdev, RS690_HTIU_NB_INDEX, | ||||
| 				RS690_LOWER_TOP_OF_DRAM2); | ||||
| 	pci_read_config_dword(pdev, RS690_HTIU_NB_DATA, &val); | ||||
| 
 | ||||
| 	if (val) | ||||
| 		return; | ||||
| 
 | ||||
| 	pci_info(pdev, "Adjusting top of DRAM to %pa for 64-bit DMA support\n", &top_of_dram); | ||||
| 
 | ||||
| 	pci_write_config_dword(pdev, RS690_HTIU_NB_INDEX, | ||||
| 		RS690_UPPER_TOP_OF_DRAM2 | RS690_HTIU_NB_INDEX_WR_ENABLE); | ||||
| 	pci_write_config_dword(pdev, RS690_HTIU_NB_DATA, top_of_dram >> 32); | ||||
| 
 | ||||
| 	pci_write_config_dword(pdev, RS690_HTIU_NB_INDEX, | ||||
| 		RS690_LOWER_TOP_OF_DRAM2 | RS690_HTIU_NB_INDEX_WR_ENABLE); | ||||
| 	pci_write_config_dword(pdev, RS690_HTIU_NB_DATA, | ||||
| 		top_of_dram | RS690_LOWER_TOP_OF_DRAM2_VALID); | ||||
| } | ||||
| DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_ATI, 0x7910, rs690_fix_64bit_dma); | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -450,6 +450,18 @@ void __init efi_free_boot_services(void) | |||
| 			size -= rm_size; | ||||
| 		} | ||||
| 
 | ||||
| 		/*
 | ||||
| 		 * Don't free memory under 1M for two reasons: | ||||
| 		 * - BIOS might clobber it | ||||
| 		 * - Crash kernel needs it to be reserved | ||||
| 		 */ | ||||
| 		if (start + size < SZ_1M) | ||||
| 			continue; | ||||
| 		if (start < SZ_1M) { | ||||
| 			size -= (SZ_1M - start); | ||||
| 			start = SZ_1M; | ||||
| 		} | ||||
| 
 | ||||
| 		memblock_free_late(start, size); | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
|  | @ -29,14 +29,16 @@ void __init reserve_real_mode(void) | |||
| 
 | ||||
| 	/* Has to be under 1M so we can execute real-mode AP code. */ | ||||
| 	mem = memblock_find_in_range(0, 1<<20, size, PAGE_SIZE); | ||||
| 	if (!mem) { | ||||
| 	if (!mem) | ||||
| 		pr_info("No sub-1M memory is available for the trampoline\n"); | ||||
| 		return; | ||||
| 	} | ||||
| 	else | ||||
| 		set_real_mode_mem(mem); | ||||
| 
 | ||||
| 	memblock_reserve(mem, size); | ||||
| 	set_real_mode_mem(mem); | ||||
| 	crash_reserve_low_1M(); | ||||
| 	/*
 | ||||
| 	 * Unconditionally reserve the entire fisrt 1M, see comment in | ||||
| 	 * setup_arch(). | ||||
| 	 */ | ||||
| 	memblock_reserve(0, SZ_1M); | ||||
| } | ||||
| 
 | ||||
| static void sme_sev_setup_real_mode(struct trampoline_header *th) | ||||
|  |  | |||
|  | @ -233,7 +233,8 @@ async_xor_offs(struct page *dest, unsigned int offset, | |||
| 		if (submit->flags & ASYNC_TX_XOR_DROP_DST) { | ||||
| 			src_cnt--; | ||||
| 			src_list++; | ||||
| 			src_offs++; | ||||
| 			if (src_offs) | ||||
| 				src_offs++; | ||||
| 		} | ||||
| 
 | ||||
| 		/* wait for any prerequisite operations */ | ||||
|  |  | |||
|  | @ -285,6 +285,14 @@ static void acpi_ut_delete_internal_obj(union acpi_operand_object *object) | |||
| 		} | ||||
| 		break; | ||||
| 
 | ||||
| 	case ACPI_TYPE_LOCAL_ADDRESS_HANDLER: | ||||
| 
 | ||||
| 		ACPI_DEBUG_PRINT((ACPI_DB_ALLOCATIONS, | ||||
| 				  "***** Address handler %p\n", object)); | ||||
| 
 | ||||
| 		acpi_os_delete_mutex(object->address_space.context_mutex); | ||||
| 		break; | ||||
| 
 | ||||
| 	default: | ||||
| 
 | ||||
| 		break; | ||||
|  |  | |||
|  | @ -330,32 +330,21 @@ static void acpi_bus_osc_negotiate_platform_control(void) | |||
| 	if (ACPI_FAILURE(acpi_run_osc(handle, &context))) | ||||
| 		return; | ||||
| 
 | ||||
| 	capbuf_ret = context.ret.pointer; | ||||
| 	if (context.ret.length <= OSC_SUPPORT_DWORD) { | ||||
| 		kfree(context.ret.pointer); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * Now run _OSC again with query flag clear and with the caps | ||||
| 	 * supported by both the OS and the platform. | ||||
| 	 */ | ||||
| 	capbuf[OSC_QUERY_DWORD] = 0; | ||||
| 	capbuf[OSC_SUPPORT_DWORD] = capbuf_ret[OSC_SUPPORT_DWORD]; | ||||
| 	kfree(context.ret.pointer); | ||||
| 
 | ||||
| 	/* Now run _OSC again with query flag clear */ | ||||
| 	capbuf[OSC_QUERY_DWORD] = 0; | ||||
| 
 | ||||
| 	if (ACPI_FAILURE(acpi_run_osc(handle, &context))) | ||||
| 		return; | ||||
| 
 | ||||
| 	capbuf_ret = context.ret.pointer; | ||||
| 	if (context.ret.length > OSC_SUPPORT_DWORD) { | ||||
| 		osc_sb_apei_support_acked = | ||||
| 			capbuf_ret[OSC_SUPPORT_DWORD] & OSC_SB_APEI_SUPPORT; | ||||
| 		osc_pc_lpi_support_confirmed = | ||||
| 			capbuf_ret[OSC_SUPPORT_DWORD] & OSC_SB_PCLPI_SUPPORT; | ||||
| 		osc_sb_native_usb4_support_confirmed = | ||||
| 			capbuf_ret[OSC_SUPPORT_DWORD] & OSC_SB_NATIVE_USB4_SUPPORT; | ||||
| 	} | ||||
| 	osc_sb_apei_support_acked = | ||||
| 		capbuf_ret[OSC_SUPPORT_DWORD] & OSC_SB_APEI_SUPPORT; | ||||
| 	osc_pc_lpi_support_confirmed = | ||||
| 		capbuf_ret[OSC_SUPPORT_DWORD] & OSC_SB_PCLPI_SUPPORT; | ||||
| 	osc_sb_native_usb4_support_confirmed = | ||||
| 		capbuf_ret[OSC_SUPPORT_DWORD] & OSC_SB_NATIVE_USB4_SUPPORT; | ||||
| 
 | ||||
| 	kfree(context.ret.pointer); | ||||
| } | ||||
|  |  | |||
|  | @ -1009,10 +1009,8 @@ static void acpi_sleep_hibernate_setup(void) | |||
| 		return; | ||||
| 
 | ||||
| 	acpi_get_table(ACPI_SIG_FACS, 1, (struct acpi_table_header **)&facs); | ||||
| 	if (facs) { | ||||
| 	if (facs) | ||||
| 		s4_hardware_signature = facs->hardware_signature; | ||||
| 		acpi_put_table((struct acpi_table_header *)facs); | ||||
| 	} | ||||
| } | ||||
| #else /* !CONFIG_HIBERNATION */ | ||||
| static inline void acpi_sleep_hibernate_setup(void) {} | ||||
|  |  | |||
|  | @ -218,14 +218,14 @@ static int memory_block_offline(struct memory_block *mem) | |||
| 	struct zone *zone; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	zone = page_zone(pfn_to_page(start_pfn)); | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * Unaccount before offlining, such that unpopulated zone and kthreads | ||||
| 	 * can properly be torn down in offline_pages(). | ||||
| 	 */ | ||||
| 	if (nr_vmemmap_pages) | ||||
| 	if (nr_vmemmap_pages) { | ||||
| 		zone = page_zone(pfn_to_page(start_pfn)); | ||||
| 		adjust_present_page_count(zone, -nr_vmemmap_pages); | ||||
| 	} | ||||
| 
 | ||||
| 	ret = offline_pages(start_pfn + nr_vmemmap_pages, | ||||
| 			    nr_pages - nr_vmemmap_pages); | ||||
|  |  | |||
|  | @ -1879,29 +1879,18 @@ static int lo_compat_ioctl(struct block_device *bdev, fmode_t mode, | |||
| 
 | ||||
| static int lo_open(struct block_device *bdev, fmode_t mode) | ||||
| { | ||||
| 	struct loop_device *lo; | ||||
| 	struct loop_device *lo = bdev->bd_disk->private_data; | ||||
| 	int err; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * take loop_ctl_mutex to protect lo pointer from race with | ||||
| 	 * loop_control_ioctl(LOOP_CTL_REMOVE), however, to reduce contention | ||||
| 	 * release it prior to updating lo->lo_refcnt. | ||||
| 	 */ | ||||
| 	err = mutex_lock_killable(&loop_ctl_mutex); | ||||
| 	if (err) | ||||
| 		return err; | ||||
| 	lo = bdev->bd_disk->private_data; | ||||
| 	if (!lo) { | ||||
| 		mutex_unlock(&loop_ctl_mutex); | ||||
| 		return -ENXIO; | ||||
| 	} | ||||
| 	err = mutex_lock_killable(&lo->lo_mutex); | ||||
| 	mutex_unlock(&loop_ctl_mutex); | ||||
| 	if (err) | ||||
| 		return err; | ||||
| 	atomic_inc(&lo->lo_refcnt); | ||||
| 	if (lo->lo_state == Lo_deleting) | ||||
| 		err = -ENXIO; | ||||
| 	else | ||||
| 		atomic_inc(&lo->lo_refcnt); | ||||
| 	mutex_unlock(&lo->lo_mutex); | ||||
| 	return 0; | ||||
| 	return err; | ||||
| } | ||||
| 
 | ||||
| static void lo_release(struct gendisk *disk, fmode_t mode) | ||||
|  | @ -2285,7 +2274,7 @@ static long loop_control_ioctl(struct file *file, unsigned int cmd, | |||
| 			mutex_unlock(&lo->lo_mutex); | ||||
| 			break; | ||||
| 		} | ||||
| 		lo->lo_disk->private_data = NULL; | ||||
| 		lo->lo_state = Lo_deleting; | ||||
| 		mutex_unlock(&lo->lo_mutex); | ||||
| 		idr_remove(&loop_index_idr, lo->lo_number); | ||||
| 		loop_remove(lo); | ||||
|  |  | |||
|  | @ -22,6 +22,7 @@ enum { | |||
| 	Lo_unbound, | ||||
| 	Lo_bound, | ||||
| 	Lo_rundown, | ||||
| 	Lo_deleting, | ||||
| }; | ||||
| 
 | ||||
| struct loop_func_table; | ||||
|  |  | |||
|  | @ -388,6 +388,8 @@ static const struct usb_device_id blacklist_table[] = { | |||
| 	/* Realtek 8822CE Bluetooth devices */ | ||||
| 	{ USB_DEVICE(0x0bda, 0xb00c), .driver_info = BTUSB_REALTEK | | ||||
| 						     BTUSB_WIDEBAND_SPEECH }, | ||||
| 	{ USB_DEVICE(0x0bda, 0xc822), .driver_info = BTUSB_REALTEK | | ||||
| 						     BTUSB_WIDEBAND_SPEECH }, | ||||
| 
 | ||||
| 	/* Realtek 8852AE Bluetooth devices */ | ||||
| 	{ USB_DEVICE(0x0bda, 0xc852), .driver_info = BTUSB_REALTEK | | ||||
|  | @ -2527,10 +2529,17 @@ static int btusb_intel_download_firmware_newgen(struct hci_dev *hdev, | |||
| 	} | ||||
| 
 | ||||
| 	btusb_setup_intel_newgen_get_fw_name(ver, fwname, sizeof(fwname), "sfi"); | ||||
| 	err = request_firmware(&fw, fwname, &hdev->dev); | ||||
| 	err = firmware_request_nowarn(&fw, fwname, &hdev->dev); | ||||
| 	if (err < 0) { | ||||
| 		if (!test_bit(BTUSB_BOOTLOADER, &data->flags)) { | ||||
| 			/* Firmware has already been loaded */ | ||||
| 			set_bit(BTUSB_FIRMWARE_LOADED, &data->flags); | ||||
| 			return 0; | ||||
| 		} | ||||
| 
 | ||||
| 		bt_dev_err(hdev, "Failed to load Intel firmware file %s (%d)", | ||||
| 			   fwname, err); | ||||
| 
 | ||||
| 		return err; | ||||
| 	} | ||||
| 
 | ||||
|  | @ -2680,12 +2689,24 @@ download: | |||
| 	err = btusb_setup_intel_new_get_fw_name(ver, params, fwname, | ||||
| 						sizeof(fwname), "sfi"); | ||||
| 	if (err < 0) { | ||||
| 		if (!test_bit(BTUSB_BOOTLOADER, &data->flags)) { | ||||
| 			/* Firmware has already been loaded */ | ||||
| 			set_bit(BTUSB_FIRMWARE_LOADED, &data->flags); | ||||
| 			return 0; | ||||
| 		} | ||||
| 
 | ||||
| 		bt_dev_err(hdev, "Unsupported Intel firmware naming"); | ||||
| 		return -EINVAL; | ||||
| 	} | ||||
| 
 | ||||
| 	err = request_firmware(&fw, fwname, &hdev->dev); | ||||
| 	err = firmware_request_nowarn(&fw, fwname, &hdev->dev); | ||||
| 	if (err < 0) { | ||||
| 		if (!test_bit(BTUSB_BOOTLOADER, &data->flags)) { | ||||
| 			/* Firmware has already been loaded */ | ||||
| 			set_bit(BTUSB_FIRMWARE_LOADED, &data->flags); | ||||
| 			return 0; | ||||
| 		} | ||||
| 
 | ||||
| 		bt_dev_err(hdev, "Failed to load Intel firmware file %s (%d)", | ||||
| 			   fwname, err); | ||||
| 		return err; | ||||
|  |  | |||
|  | @ -311,8 +311,8 @@ static const struct mhi_channel_config mhi_foxconn_sdx55_channels[] = { | |||
| 	MHI_CHANNEL_CONFIG_DL(5, "DIAG", 32, 1), | ||||
| 	MHI_CHANNEL_CONFIG_UL(12, "MBIM", 32, 0), | ||||
| 	MHI_CHANNEL_CONFIG_DL(13, "MBIM", 32, 0), | ||||
| 	MHI_CHANNEL_CONFIG_UL(32, "AT", 32, 0), | ||||
| 	MHI_CHANNEL_CONFIG_DL(33, "AT", 32, 0), | ||||
| 	MHI_CHANNEL_CONFIG_UL(32, "DUN", 32, 0), | ||||
| 	MHI_CHANNEL_CONFIG_DL(33, "DUN", 32, 0), | ||||
| 	MHI_CHANNEL_CONFIG_HW_UL(100, "IP_HW0_MBIM", 128, 2), | ||||
| 	MHI_CHANNEL_CONFIG_HW_DL(101, "IP_HW0_MBIM", 128, 3), | ||||
| }; | ||||
|  | @ -708,7 +708,7 @@ static void mhi_pci_remove(struct pci_dev *pdev) | |||
| 	struct mhi_pci_device *mhi_pdev = pci_get_drvdata(pdev); | ||||
| 	struct mhi_controller *mhi_cntrl = &mhi_pdev->mhi_cntrl; | ||||
| 
 | ||||
| 	del_timer(&mhi_pdev->health_check_timer); | ||||
| 	del_timer_sync(&mhi_pdev->health_check_timer); | ||||
| 	cancel_work_sync(&mhi_pdev->recovery_work); | ||||
| 
 | ||||
| 	if (test_and_clear_bit(MHI_PCI_DEV_STARTED, &mhi_pdev->status)) { | ||||
|  | @ -935,9 +935,43 @@ static int __maybe_unused mhi_pci_resume(struct device *dev) | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| static int __maybe_unused mhi_pci_freeze(struct device *dev) | ||||
| { | ||||
| 	struct mhi_pci_device *mhi_pdev = dev_get_drvdata(dev); | ||||
| 	struct mhi_controller *mhi_cntrl = &mhi_pdev->mhi_cntrl; | ||||
| 
 | ||||
| 	/* We want to stop all operations, hibernation does not guarantee that
 | ||||
| 	 * device will be in the same state as before freezing, especially if | ||||
| 	 * the intermediate restore kernel reinitializes MHI device with new | ||||
| 	 * context. | ||||
| 	 */ | ||||
| 	if (test_and_clear_bit(MHI_PCI_DEV_STARTED, &mhi_pdev->status)) { | ||||
| 		mhi_power_down(mhi_cntrl, false); | ||||
| 		mhi_unprepare_after_power_down(mhi_cntrl); | ||||
| 	} | ||||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| static int __maybe_unused mhi_pci_restore(struct device *dev) | ||||
| { | ||||
| 	struct mhi_pci_device *mhi_pdev = dev_get_drvdata(dev); | ||||
| 
 | ||||
| 	/* Reinitialize the device */ | ||||
| 	queue_work(system_long_wq, &mhi_pdev->recovery_work); | ||||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| static const struct dev_pm_ops mhi_pci_pm_ops = { | ||||
| 	SET_RUNTIME_PM_OPS(mhi_pci_runtime_suspend, mhi_pci_runtime_resume, NULL) | ||||
| 	SET_SYSTEM_SLEEP_PM_OPS(mhi_pci_suspend, mhi_pci_resume) | ||||
| #ifdef CONFIG_PM_SLEEP | ||||
| 	.suspend = mhi_pci_suspend, | ||||
| 	.resume = mhi_pci_resume, | ||||
| 	.freeze = mhi_pci_freeze, | ||||
| 	.thaw = mhi_pci_restore, | ||||
| 	.restore = mhi_pci_restore, | ||||
| #endif | ||||
| }; | ||||
| 
 | ||||
| static struct pci_driver mhi_pci_driver = { | ||||
|  |  | |||
|  | @ -1334,6 +1334,34 @@ err_allow_idle: | |||
| 	return error; | ||||
| } | ||||
| 
 | ||||
| static int sysc_reinit_module(struct sysc *ddata, bool leave_enabled) | ||||
| { | ||||
| 	struct device *dev = ddata->dev; | ||||
| 	int error; | ||||
| 
 | ||||
| 	/* Disable target module if it is enabled */ | ||||
| 	if (ddata->enabled) { | ||||
| 		error = sysc_runtime_suspend(dev); | ||||
| 		if (error) | ||||
| 			dev_warn(dev, "reinit suspend failed: %i\n", error); | ||||
| 	} | ||||
| 
 | ||||
| 	/* Enable target module */ | ||||
| 	error = sysc_runtime_resume(dev); | ||||
| 	if (error) | ||||
| 		dev_warn(dev, "reinit resume failed: %i\n", error); | ||||
| 
 | ||||
| 	if (leave_enabled) | ||||
| 		return error; | ||||
| 
 | ||||
| 	/* Disable target module if no leave_enabled was set */ | ||||
| 	error = sysc_runtime_suspend(dev); | ||||
| 	if (error) | ||||
| 		dev_warn(dev, "reinit suspend failed: %i\n", error); | ||||
| 
 | ||||
| 	return error; | ||||
| } | ||||
| 
 | ||||
| static int __maybe_unused sysc_noirq_suspend(struct device *dev) | ||||
| { | ||||
| 	struct sysc *ddata; | ||||
|  | @ -1344,12 +1372,18 @@ static int __maybe_unused sysc_noirq_suspend(struct device *dev) | |||
| 	    (SYSC_QUIRK_LEGACY_IDLE | SYSC_QUIRK_NO_IDLE)) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	return pm_runtime_force_suspend(dev); | ||||
| 	if (!ddata->enabled) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	ddata->needs_resume = 1; | ||||
| 
 | ||||
| 	return sysc_runtime_suspend(dev); | ||||
| } | ||||
| 
 | ||||
| static int __maybe_unused sysc_noirq_resume(struct device *dev) | ||||
| { | ||||
| 	struct sysc *ddata; | ||||
| 	int error = 0; | ||||
| 
 | ||||
| 	ddata = dev_get_drvdata(dev); | ||||
| 
 | ||||
|  | @ -1357,7 +1391,19 @@ static int __maybe_unused sysc_noirq_resume(struct device *dev) | |||
| 	    (SYSC_QUIRK_LEGACY_IDLE | SYSC_QUIRK_NO_IDLE)) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	return pm_runtime_force_resume(dev); | ||||
| 	if (ddata->cfg.quirks & SYSC_QUIRK_REINIT_ON_RESUME) { | ||||
| 		error = sysc_reinit_module(ddata, ddata->needs_resume); | ||||
| 		if (error) | ||||
| 			dev_warn(dev, "noirq_resume failed: %i\n", error); | ||||
| 	} else if (ddata->needs_resume) { | ||||
| 		error = sysc_runtime_resume(dev); | ||||
| 		if (error) | ||||
| 			dev_warn(dev, "noirq_resume failed: %i\n", error); | ||||
| 	} | ||||
| 
 | ||||
| 	ddata->needs_resume = 0; | ||||
| 
 | ||||
| 	return error; | ||||
| } | ||||
| 
 | ||||
| static const struct dev_pm_ops sysc_pm_ops = { | ||||
|  | @ -1408,9 +1454,9 @@ static const struct sysc_revision_quirk sysc_revision_quirks[] = { | |||
| 		   SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_LEGACY_IDLE), | ||||
| 	/* Uarts on omap4 and later */ | ||||
| 	SYSC_QUIRK("uart", 0, 0x50, 0x54, 0x58, 0x50411e03, 0xffff00ff, | ||||
| 		   SYSC_QUIRK_SWSUP_SIDLE_ACT | SYSC_QUIRK_LEGACY_IDLE), | ||||
| 		   SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_LEGACY_IDLE), | ||||
| 	SYSC_QUIRK("uart", 0, 0x50, 0x54, 0x58, 0x47422e03, 0xffffffff, | ||||
| 		   SYSC_QUIRK_SWSUP_SIDLE_ACT | SYSC_QUIRK_LEGACY_IDLE), | ||||
| 		   SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_LEGACY_IDLE), | ||||
| 
 | ||||
| 	/* Quirks that need to be set based on the module address */ | ||||
| 	SYSC_QUIRK("mcpdm", 0x40132000, 0, 0x10, -ENODEV, 0x50000800, 0xffffffff, | ||||
|  | @ -1459,6 +1505,8 @@ static const struct sysc_revision_quirk sysc_revision_quirks[] = { | |||
| 		   SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_SWSUP_MSTANDBY), | ||||
| 	SYSC_QUIRK("tptc", 0, 0, -ENODEV, -ENODEV, 0x40007c00, 0xffffffff, | ||||
| 		   SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_SWSUP_MSTANDBY), | ||||
| 	SYSC_QUIRK("sata", 0, 0xfc, 0x1100, -ENODEV, 0x5e412000, 0xffffffff, | ||||
| 		   SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_SWSUP_MSTANDBY), | ||||
| 	SYSC_QUIRK("usb_host_hs", 0, 0, 0x10, 0x14, 0x50700100, 0xffffffff, | ||||
| 		   SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_SWSUP_MSTANDBY), | ||||
| 	SYSC_QUIRK("usb_host_hs", 0, 0, 0x10, -ENODEV, 0x50700101, 0xffffffff, | ||||
|  | @ -1466,7 +1514,8 @@ static const struct sysc_revision_quirk sysc_revision_quirks[] = { | |||
| 	SYSC_QUIRK("usb_otg_hs", 0, 0x400, 0x404, 0x408, 0x00000050, | ||||
| 		   0xffffffff, SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_SWSUP_MSTANDBY), | ||||
| 	SYSC_QUIRK("usb_otg_hs", 0, 0, 0x10, -ENODEV, 0x4ea2080d, 0xffffffff, | ||||
| 		   SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_SWSUP_MSTANDBY), | ||||
| 		   SYSC_QUIRK_SWSUP_SIDLE | SYSC_QUIRK_SWSUP_MSTANDBY | | ||||
| 		   SYSC_QUIRK_REINIT_ON_RESUME), | ||||
| 	SYSC_QUIRK("wdt", 0, 0, 0x10, 0x14, 0x502a0500, 0xfffff0f0, | ||||
| 		   SYSC_MODULE_QUIRK_WDT), | ||||
| 	/* PRUSS on am3, am4 and am5 */ | ||||
|  | @ -1524,7 +1573,6 @@ static const struct sysc_revision_quirk sysc_revision_quirks[] = { | |||
| 	SYSC_QUIRK("prcm", 0, 0, -ENODEV, -ENODEV, 0x40000400, 0xffffffff, 0), | ||||
| 	SYSC_QUIRK("rfbi", 0x4832a800, 0, 0x10, 0x14, 0x00000010, 0xffffffff, 0), | ||||
| 	SYSC_QUIRK("rfbi", 0x58002000, 0, 0x10, 0x14, 0x00000010, 0xffffffff, 0), | ||||
| 	SYSC_QUIRK("sata", 0, 0xfc, 0x1100, -ENODEV, 0x5e412000, 0xffffffff, 0), | ||||
| 	SYSC_QUIRK("scm", 0, 0, 0x10, -ENODEV, 0x40000900, 0xffffffff, 0), | ||||
| 	SYSC_QUIRK("scm", 0, 0, -ENODEV, -ENODEV, 0x4e8b0100, 0xffffffff, 0), | ||||
| 	SYSC_QUIRK("scm", 0, 0, -ENODEV, -ENODEV, 0x4f000100, 0xffffffff, 0), | ||||
|  |  | |||
|  | @ -19,16 +19,6 @@ config ACPI_CPPC_CPUFREQ | |||
| 
 | ||||
| 	  If in doubt, say N. | ||||
| 
 | ||||
| config ACPI_CPPC_CPUFREQ_FIE | ||||
| 	bool "Frequency Invariance support for CPPC cpufreq driver" | ||||
| 	depends on ACPI_CPPC_CPUFREQ && GENERIC_ARCH_TOPOLOGY | ||||
| 	default y | ||||
| 	help | ||||
| 	  This extends frequency invariance support in the CPPC cpufreq driver, | ||||
| 	  by using CPPC delivered and reference performance counters. | ||||
| 
 | ||||
| 	  If in doubt, say N. | ||||
| 
 | ||||
| config ARM_ALLWINNER_SUN50I_CPUFREQ_NVMEM | ||||
| 	tristate "Allwinner nvmem based SUN50I CPUFreq driver" | ||||
| 	depends on ARCH_SUNXI | ||||
|  |  | |||
|  | @ -10,18 +10,14 @@ | |||
| 
 | ||||
| #define pr_fmt(fmt)	"CPPC Cpufreq:"	fmt | ||||
| 
 | ||||
| #include <linux/arch_topology.h> | ||||
| #include <linux/kernel.h> | ||||
| #include <linux/module.h> | ||||
| #include <linux/delay.h> | ||||
| #include <linux/cpu.h> | ||||
| #include <linux/cpufreq.h> | ||||
| #include <linux/dmi.h> | ||||
| #include <linux/irq_work.h> | ||||
| #include <linux/kthread.h> | ||||
| #include <linux/time.h> | ||||
| #include <linux/vmalloc.h> | ||||
| #include <uapi/linux/sched/types.h> | ||||
| 
 | ||||
| #include <asm/unaligned.h> | ||||
| 
 | ||||
|  | @ -61,204 +57,6 @@ static struct cppc_workaround_oem_info wa_info[] = { | |||
| 	} | ||||
| }; | ||||
| 
 | ||||
| #ifdef CONFIG_ACPI_CPPC_CPUFREQ_FIE | ||||
| 
 | ||||
| /* Frequency invariance support */ | ||||
| struct cppc_freq_invariance { | ||||
| 	int cpu; | ||||
| 	struct irq_work irq_work; | ||||
| 	struct kthread_work work; | ||||
| 	struct cppc_perf_fb_ctrs prev_perf_fb_ctrs; | ||||
| 	struct cppc_cpudata *cpu_data; | ||||
| }; | ||||
| 
 | ||||
| static DEFINE_PER_CPU(struct cppc_freq_invariance, cppc_freq_inv); | ||||
| static struct kthread_worker *kworker_fie; | ||||
| static bool fie_disabled; | ||||
| 
 | ||||
| static struct cpufreq_driver cppc_cpufreq_driver; | ||||
| static unsigned int hisi_cppc_cpufreq_get_rate(unsigned int cpu); | ||||
| static int cppc_perf_from_fbctrs(struct cppc_cpudata *cpu_data, | ||||
| 				 struct cppc_perf_fb_ctrs fb_ctrs_t0, | ||||
| 				 struct cppc_perf_fb_ctrs fb_ctrs_t1); | ||||
| 
 | ||||
| /**
 | ||||
|  * cppc_scale_freq_workfn - CPPC arch_freq_scale updater for frequency invariance | ||||
|  * @work: The work item. | ||||
|  * | ||||
|  * The CPPC driver register itself with the topology core to provide its own | ||||
|  * implementation (cppc_scale_freq_tick()) of topology_scale_freq_tick() which | ||||
|  * gets called by the scheduler on every tick. | ||||
|  * | ||||
|  * Note that the arch specific counters have higher priority than CPPC counters, | ||||
|  * if available, though the CPPC driver doesn't need to have any special | ||||
|  * handling for that. | ||||
|  * | ||||
|  * On an invocation of cppc_scale_freq_tick(), we schedule an irq work (since we | ||||
|  * reach here from hard-irq context), which then schedules a normal work item | ||||
|  * and cppc_scale_freq_workfn() updates the per_cpu arch_freq_scale variable | ||||
|  * based on the counter updates since the last tick. | ||||
|  */ | ||||
| static void cppc_scale_freq_workfn(struct kthread_work *work) | ||||
| { | ||||
| 	struct cppc_freq_invariance *cppc_fi; | ||||
| 	struct cppc_perf_fb_ctrs fb_ctrs = {0}; | ||||
| 	struct cppc_cpudata *cpu_data; | ||||
| 	unsigned long local_freq_scale; | ||||
| 	u64 perf; | ||||
| 
 | ||||
| 	cppc_fi = container_of(work, struct cppc_freq_invariance, work); | ||||
| 	cpu_data = cppc_fi->cpu_data; | ||||
| 
 | ||||
| 	if (cppc_get_perf_ctrs(cppc_fi->cpu, &fb_ctrs)) { | ||||
| 		pr_warn("%s: failed to read perf counters\n", __func__); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	cppc_fi->prev_perf_fb_ctrs = fb_ctrs; | ||||
| 	perf = cppc_perf_from_fbctrs(cpu_data, cppc_fi->prev_perf_fb_ctrs, | ||||
| 				     fb_ctrs); | ||||
| 
 | ||||
| 	perf <<= SCHED_CAPACITY_SHIFT; | ||||
| 	local_freq_scale = div64_u64(perf, cpu_data->perf_caps.highest_perf); | ||||
| 	if (WARN_ON(local_freq_scale > 1024)) | ||||
| 		local_freq_scale = 1024; | ||||
| 
 | ||||
| 	per_cpu(arch_freq_scale, cppc_fi->cpu) = local_freq_scale; | ||||
| } | ||||
| 
 | ||||
| static void cppc_irq_work(struct irq_work *irq_work) | ||||
| { | ||||
| 	struct cppc_freq_invariance *cppc_fi; | ||||
| 
 | ||||
| 	cppc_fi = container_of(irq_work, struct cppc_freq_invariance, irq_work); | ||||
| 	kthread_queue_work(kworker_fie, &cppc_fi->work); | ||||
| } | ||||
| 
 | ||||
| static void cppc_scale_freq_tick(void) | ||||
| { | ||||
| 	struct cppc_freq_invariance *cppc_fi = &per_cpu(cppc_freq_inv, smp_processor_id()); | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * cppc_get_perf_ctrs() can potentially sleep, call that from the right | ||||
| 	 * context. | ||||
| 	 */ | ||||
| 	irq_work_queue(&cppc_fi->irq_work); | ||||
| } | ||||
| 
 | ||||
| static struct scale_freq_data cppc_sftd = { | ||||
| 	.source = SCALE_FREQ_SOURCE_CPPC, | ||||
| 	.set_freq_scale = cppc_scale_freq_tick, | ||||
| }; | ||||
| 
 | ||||
| static void cppc_freq_invariance_policy_init(struct cpufreq_policy *policy, | ||||
| 					     struct cppc_cpudata *cpu_data) | ||||
| { | ||||
| 	struct cppc_perf_fb_ctrs fb_ctrs = {0}; | ||||
| 	struct cppc_freq_invariance *cppc_fi; | ||||
| 	int i, ret; | ||||
| 
 | ||||
| 	if (cppc_cpufreq_driver.get == hisi_cppc_cpufreq_get_rate) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (fie_disabled) | ||||
| 		return; | ||||
| 
 | ||||
| 	for_each_cpu(i, policy->cpus) { | ||||
| 		cppc_fi = &per_cpu(cppc_freq_inv, i); | ||||
| 		cppc_fi->cpu = i; | ||||
| 		cppc_fi->cpu_data = cpu_data; | ||||
| 		kthread_init_work(&cppc_fi->work, cppc_scale_freq_workfn); | ||||
| 		init_irq_work(&cppc_fi->irq_work, cppc_irq_work); | ||||
| 
 | ||||
| 		ret = cppc_get_perf_ctrs(i, &fb_ctrs); | ||||
| 		if (ret) { | ||||
| 			pr_warn("%s: failed to read perf counters: %d\n", | ||||
| 				__func__, ret); | ||||
| 			fie_disabled = true; | ||||
| 		} else { | ||||
| 			cppc_fi->prev_perf_fb_ctrs = fb_ctrs; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void __init cppc_freq_invariance_init(void) | ||||
| { | ||||
| 	struct sched_attr attr = { | ||||
| 		.size		= sizeof(struct sched_attr), | ||||
| 		.sched_policy	= SCHED_DEADLINE, | ||||
| 		.sched_nice	= 0, | ||||
| 		.sched_priority	= 0, | ||||
| 		/*
 | ||||
| 		 * Fake (unused) bandwidth; workaround to "fix" | ||||
| 		 * priority inheritance. | ||||
| 		 */ | ||||
| 		.sched_runtime	= 1000000, | ||||
| 		.sched_deadline = 10000000, | ||||
| 		.sched_period	= 10000000, | ||||
| 	}; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	if (cppc_cpufreq_driver.get == hisi_cppc_cpufreq_get_rate) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (fie_disabled) | ||||
| 		return; | ||||
| 
 | ||||
| 	kworker_fie = kthread_create_worker(0, "cppc_fie"); | ||||
| 	if (IS_ERR(kworker_fie)) | ||||
| 		return; | ||||
| 
 | ||||
| 	ret = sched_setattr_nocheck(kworker_fie->task, &attr); | ||||
| 	if (ret) { | ||||
| 		pr_warn("%s: failed to set SCHED_DEADLINE: %d\n", __func__, | ||||
| 			ret); | ||||
| 		kthread_destroy_worker(kworker_fie); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	/* Register for freq-invariance */ | ||||
| 	topology_set_scale_freq_source(&cppc_sftd, cpu_present_mask); | ||||
| } | ||||
| 
 | ||||
| static void cppc_freq_invariance_exit(void) | ||||
| { | ||||
| 	struct cppc_freq_invariance *cppc_fi; | ||||
| 	int i; | ||||
| 
 | ||||
| 	if (cppc_cpufreq_driver.get == hisi_cppc_cpufreq_get_rate) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (fie_disabled) | ||||
| 		return; | ||||
| 
 | ||||
| 	topology_clear_scale_freq_source(SCALE_FREQ_SOURCE_CPPC, cpu_present_mask); | ||||
| 
 | ||||
| 	for_each_possible_cpu(i) { | ||||
| 		cppc_fi = &per_cpu(cppc_freq_inv, i); | ||||
| 		irq_work_sync(&cppc_fi->irq_work); | ||||
| 	} | ||||
| 
 | ||||
| 	kthread_destroy_worker(kworker_fie); | ||||
| 	kworker_fie = NULL; | ||||
| } | ||||
| 
 | ||||
| #else | ||||
| static inline void | ||||
| cppc_freq_invariance_policy_init(struct cpufreq_policy *policy, | ||||
| 				 struct cppc_cpudata *cpu_data) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| static inline void cppc_freq_invariance_init(void) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| static inline void cppc_freq_invariance_exit(void) | ||||
| { | ||||
| } | ||||
| #endif /* CONFIG_ACPI_CPPC_CPUFREQ_FIE */ | ||||
| 
 | ||||
| /* Callback function used to retrieve the max frequency from DMI */ | ||||
| static void cppc_find_dmi_mhz(const struct dmi_header *dm, void *private) | ||||
| { | ||||
|  | @ -547,12 +345,9 @@ static int cppc_cpufreq_cpu_init(struct cpufreq_policy *policy) | |||
| 	cpu_data->perf_ctrls.desired_perf =  caps->highest_perf; | ||||
| 
 | ||||
| 	ret = cppc_set_perf(cpu, &cpu_data->perf_ctrls); | ||||
| 	if (ret) { | ||||
| 	if (ret) | ||||
| 		pr_debug("Err setting perf value:%d on CPU:%d. ret:%d\n", | ||||
| 			 caps->highest_perf, cpu, ret); | ||||
| 	} else { | ||||
| 		cppc_freq_invariance_policy_init(policy, cpu_data); | ||||
| 	} | ||||
| 
 | ||||
| 	return ret; | ||||
| } | ||||
|  | @ -565,12 +360,12 @@ static inline u64 get_delta(u64 t1, u64 t0) | |||
| 	return (u32)t1 - (u32)t0; | ||||
| } | ||||
| 
 | ||||
| static int cppc_perf_from_fbctrs(struct cppc_cpudata *cpu_data, | ||||
| 				 struct cppc_perf_fb_ctrs fb_ctrs_t0, | ||||
| 				 struct cppc_perf_fb_ctrs fb_ctrs_t1) | ||||
| static int cppc_get_rate_from_fbctrs(struct cppc_cpudata *cpu_data, | ||||
| 				     struct cppc_perf_fb_ctrs fb_ctrs_t0, | ||||
| 				     struct cppc_perf_fb_ctrs fb_ctrs_t1) | ||||
| { | ||||
| 	u64 delta_reference, delta_delivered; | ||||
| 	u64 reference_perf; | ||||
| 	u64 reference_perf, delivered_perf; | ||||
| 
 | ||||
| 	reference_perf = fb_ctrs_t0.reference_perf; | ||||
| 
 | ||||
|  | @ -579,21 +374,12 @@ static int cppc_perf_from_fbctrs(struct cppc_cpudata *cpu_data, | |||
| 	delta_delivered = get_delta(fb_ctrs_t1.delivered, | ||||
| 				    fb_ctrs_t0.delivered); | ||||
| 
 | ||||
| 	/* Check to avoid divide-by zero and invalid delivered_perf */ | ||||
| 	if (!delta_reference || !delta_delivered) | ||||
| 		return cpu_data->perf_ctrls.desired_perf; | ||||
| 
 | ||||
| 	return (reference_perf * delta_delivered) / delta_reference; | ||||
| } | ||||
| 
 | ||||
| static int cppc_get_rate_from_fbctrs(struct cppc_cpudata *cpu_data, | ||||
| 				     struct cppc_perf_fb_ctrs fb_ctrs_t0, | ||||
| 				     struct cppc_perf_fb_ctrs fb_ctrs_t1) | ||||
| { | ||||
| 	u64 delivered_perf; | ||||
| 
 | ||||
| 	delivered_perf = cppc_perf_from_fbctrs(cpu_data, fb_ctrs_t0, | ||||
| 					       fb_ctrs_t1); | ||||
| 	/* Check to avoid divide-by zero */ | ||||
| 	if (delta_reference || delta_delivered) | ||||
| 		delivered_perf = (reference_perf * delta_delivered) / | ||||
| 					delta_reference; | ||||
| 	else | ||||
| 		delivered_perf = cpu_data->perf_ctrls.desired_perf; | ||||
| 
 | ||||
| 	return cppc_cpufreq_perf_to_khz(cpu_data, delivered_perf); | ||||
| } | ||||
|  | @ -718,8 +504,6 @@ static void cppc_check_hisi_workaround(void) | |||
| 
 | ||||
| static int __init cppc_cpufreq_init(void) | ||||
| { | ||||
| 	int ret; | ||||
| 
 | ||||
| 	if ((acpi_disabled) || !acpi_cpc_valid()) | ||||
| 		return -ENODEV; | ||||
| 
 | ||||
|  | @ -727,11 +511,7 @@ static int __init cppc_cpufreq_init(void) | |||
| 
 | ||||
| 	cppc_check_hisi_workaround(); | ||||
| 
 | ||||
| 	ret = cpufreq_register_driver(&cppc_cpufreq_driver); | ||||
| 	if (!ret) | ||||
| 		cppc_freq_invariance_init(); | ||||
| 
 | ||||
| 	return ret; | ||||
| 	return cpufreq_register_driver(&cppc_cpufreq_driver); | ||||
| } | ||||
| 
 | ||||
| static inline void free_cpu_data(void) | ||||
|  | @ -748,7 +528,6 @@ static inline void free_cpu_data(void) | |||
| 
 | ||||
| static void __exit cppc_cpufreq_exit(void) | ||||
| { | ||||
| 	cppc_freq_invariance_exit(); | ||||
| 	cpufreq_unregister_driver(&cppc_cpufreq_driver); | ||||
| 
 | ||||
| 	free_cpu_data(); | ||||
|  |  | |||
Some files were not shown because too many files have changed in this diff Show more
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Paolo Bonzini
						Paolo Bonzini