Merge branch 'perf/urgent' into perf/core, to pick up fixes
Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
		
							
								
								
									
										4
									
								
								.mailmap
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								.mailmap
									
									
									
									
									
								
							| @@ -196,7 +196,8 @@ Oleksij Rempel <linux@rempel-privat.de> <o.rempel@pengutronix.de> | ||||
| Oleksij Rempel <linux@rempel-privat.de> <ore@pengutronix.de> | ||||
| Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it> | ||||
| Patrick Mochel <mochel@digitalimplant.org> | ||||
| Paul Burton <paul.burton@mips.com> <paul.burton@imgtec.com> | ||||
| Paul Burton <paulburton@kernel.org> <paul.burton@imgtec.com> | ||||
| Paul Burton <paulburton@kernel.org> <paul.burton@mips.com> | ||||
| Peter A Jonsson <pj@ludd.ltu.se> | ||||
| Peter Oruba <peter@oruba.de> | ||||
| Peter Oruba <peter.oruba@amd.com> | ||||
| @@ -229,6 +230,7 @@ Shuah Khan <shuah@kernel.org> <shuahkhan@gmail.com> | ||||
| Shuah Khan <shuah@kernel.org> <shuah.khan@hp.com> | ||||
| Shuah Khan <shuah@kernel.org> <shuahkh@osg.samsung.com> | ||||
| Shuah Khan <shuah@kernel.org> <shuah.kh@samsung.com> | ||||
| Simon Arlott <simon@octiron.net> <simon@fire.lp0.eu> | ||||
| Simon Kelley <simon@thekelleys.org.uk> | ||||
| Stéphane Witzmann <stephane.witzmann@ubpmes.univ-bpclermont.fr> | ||||
| Stephen Hemminger <shemminger@osdl.org> | ||||
|   | ||||
| @@ -107,6 +107,8 @@ stable kernels. | ||||
| +----------------+-----------------+-----------------+-----------------------------+ | ||||
| | Cavium         | ThunderX2 SMMUv3| #126            | N/A                         | | ||||
| +----------------+-----------------+-----------------+-----------------------------+ | ||||
| | Cavium         | ThunderX2 Core  | #219            | CAVIUM_TX2_ERRATUM_219      | | ||||
| +----------------+-----------------+-----------------+-----------------------------+ | ||||
| +----------------+-----------------+-----------------+-----------------------------+ | ||||
| | Freescale/NXP  | LS2080A/LS1043A | A-008585        | FSL_ERRATUM_A008585         | | ||||
| +----------------+-----------------+-----------------+-----------------------------+ | ||||
|   | ||||
| @@ -41,6 +41,9 @@ smaller binary while the latter is 1.1 - 2 times faster. | ||||
| Both KASAN modes work with both SLUB and SLAB memory allocators. | ||||
| For better bug detection and nicer reporting, enable CONFIG_STACKTRACE. | ||||
|  | ||||
| To augment reports with last allocation and freeing stack of the physical page, | ||||
| it is recommended to enable also CONFIG_PAGE_OWNER and boot with page_owner=on. | ||||
|  | ||||
| To disable instrumentation for specific files or directories, add a line | ||||
| similar to the following to the respective kernel Makefile: | ||||
|  | ||||
|   | ||||
| @@ -496,12 +496,12 @@ properties: | ||||
|  | ||||
|       - description: Theobroma Systems RK3368-uQ7 with Haikou baseboard | ||||
|         items: | ||||
|           - const: tsd,rk3368-uq7-haikou | ||||
|           - const: tsd,rk3368-lion-haikou | ||||
|           - const: rockchip,rk3368 | ||||
|  | ||||
|       - description: Theobroma Systems RK3399-Q7 with Haikou baseboard | ||||
|         items: | ||||
|           - const: tsd,rk3399-q7-haikou | ||||
|           - const: tsd,rk3399-puma-haikou | ||||
|           - const: rockchip,rk3399 | ||||
|  | ||||
|       - description: Tronsmart Orion R68 Meta | ||||
|   | ||||
| @@ -1,8 +1,11 @@ | ||||
| * Advanced Interrupt Controller (AIC) | ||||
|  | ||||
| Required properties: | ||||
| - compatible: Should be "atmel,<chip>-aic" | ||||
|   <chip> can be "at91rm9200", "sama5d2", "sama5d3" or "sama5d4" | ||||
| - compatible: Should be: | ||||
|     - "atmel,<chip>-aic" where  <chip> can be "at91rm9200", "sama5d2", | ||||
|       "sama5d3" or "sama5d4" | ||||
|     - "microchip,<chip>-aic" where <chip> can be "sam9x60" | ||||
|  | ||||
| - interrupt-controller: Identifies the node as an interrupt controller. | ||||
| - #interrupt-cells: The number of cells to define the interrupts. It should be 3. | ||||
|   The first cell is the IRQ number (aka "Peripheral IDentifier" on datasheet). | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| # SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) | ||||
| %YAML 1.2 | ||||
| --- | ||||
| $id: http://devicetree.org/schemas/arm/allwinner,sun4i-a10-csi.yaml# | ||||
| $id: http://devicetree.org/schemas/media/allwinner,sun4i-a10-csi.yaml# | ||||
| $schema: http://devicetree.org/meta-schemas/core.yaml# | ||||
|  | ||||
| title: Allwinner A10 CMOS Sensor Interface (CSI) Device Tree Bindings | ||||
| @@ -27,14 +27,12 @@ properties: | ||||
|   clocks: | ||||
|     items: | ||||
|       - description: The CSI interface clock | ||||
|       - description: The CSI module clock | ||||
|       - description: The CSI ISP clock | ||||
|       - description: The CSI DRAM clock | ||||
|  | ||||
|   clock-names: | ||||
|     items: | ||||
|       - const: bus | ||||
|       - const: mod | ||||
|       - const: isp | ||||
|       - const: ram | ||||
|  | ||||
| @@ -89,9 +87,8 @@ examples: | ||||
|         compatible = "allwinner,sun7i-a20-csi0"; | ||||
|         reg = <0x01c09000 0x1000>; | ||||
|         interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>; | ||||
|         clocks = <&ccu CLK_AHB_CSI0>, <&ccu CLK_CSI0>, | ||||
|                  <&ccu CLK_CSI_SCLK>, <&ccu CLK_DRAM_CSI0>; | ||||
|         clock-names = "bus", "mod", "isp", "ram"; | ||||
|         clocks = <&ccu CLK_AHB_CSI0>, <&ccu CLK_CSI_SCLK>, <&ccu CLK_DRAM_CSI0>; | ||||
|         clock-names = "bus", "isp", "ram"; | ||||
|         resets = <&ccu RST_CSI0>; | ||||
|  | ||||
|         port { | ||||
|   | ||||
| @@ -33,13 +33,13 @@ patternProperties: | ||||
|           allOf: | ||||
|             - $ref: "/schemas/types.yaml#/definitions/string" | ||||
|             - enum: [ ADC0, ADC1, ADC10, ADC11, ADC12, ADC13, ADC14, ADC15, | ||||
|               ADC2, ADC3, ADC4, ADC5, ADC6, ADC7, ADC8, ADC9, BMCINT, ESPI, | ||||
|               ESPIALT, FSI1, FSI2, FWSPIABR, FWSPID, FWSPIWP, GPIT0, GPIT1, | ||||
|               GPIT2, GPIT3, GPIT4, GPIT5, GPIT6, GPIT7, GPIU0, GPIU1, GPIU2, | ||||
|               GPIU3, GPIU4, GPIU5, GPIU6, GPIU7, I2C1, I2C10, I2C11, I2C12, | ||||
|               I2C13, I2C14, I2C15, I2C16, I2C2, I2C3, I2C4, I2C5, I2C6, I2C7, | ||||
|               I2C8, I2C9, I3C3, I3C4, I3C5, I3C6, JTAGM, LHPD, LHSIRQ, LPC, | ||||
|               LPCHC, LPCPD, LPCPME, LPCSMI, LSIRQ, MACLINK1, MACLINK2, | ||||
|               ADC2, ADC3, ADC4, ADC5, ADC6, ADC7, ADC8, ADC9, BMCINT, EMMC, | ||||
|               ESPI, ESPIALT, FSI1, FSI2, FWSPIABR, FWSPID, FWSPIWP, GPIT0, | ||||
|               GPIT1, GPIT2, GPIT3, GPIT4, GPIT5, GPIT6, GPIT7, GPIU0, GPIU1, | ||||
|               GPIU2, GPIU3, GPIU4, GPIU5, GPIU6, GPIU7, I2C1, I2C10, I2C11, | ||||
|               I2C12, I2C13, I2C14, I2C15, I2C16, I2C2, I2C3, I2C4, I2C5, I2C6, | ||||
|               I2C7, I2C8, I2C9, I3C3, I3C4, I3C5, I3C6, JTAGM, LHPD, LHSIRQ, | ||||
|               LPC, LPCHC, LPCPD, LPCPME, LPCSMI, LSIRQ, MACLINK1, MACLINK2, | ||||
|               MACLINK3, MACLINK4, MDIO1, MDIO2, MDIO3, MDIO4, NCTS1, NCTS2, | ||||
|               NCTS3, NCTS4, NDCD1, NDCD2, NDCD3, NDCD4, NDSR1, NDSR2, NDSR3, | ||||
|               NDSR4, NDTR1, NDTR2, NDTR3, NDTR4, NRI1, NRI2, NRI3, NRI4, NRTS1, | ||||
| @@ -48,47 +48,45 @@ patternProperties: | ||||
|               PWM8, PWM9, RGMII1, RGMII2, RGMII3, RGMII4, RMII1, RMII2, RMII3, | ||||
|               RMII4, RXD1, RXD2, RXD3, RXD4, SALT1, SALT10, SALT11, SALT12, | ||||
|               SALT13, SALT14, SALT15, SALT16, SALT2, SALT3, SALT4, SALT5, | ||||
|               SALT6, SALT7, SALT8, SALT9, SD1, SD2, SD3, SD3DAT4, SD3DAT5, | ||||
|               SD3DAT6, SD3DAT7, SGPM1, SGPS1, SIOONCTRL, SIOPBI, SIOPBO, | ||||
|               SIOPWREQ, SIOPWRGD, SIOS3, SIOS5, SIOSCI, SPI1, SPI1ABR, SPI1CS1, | ||||
|               SPI1WP, SPI2, SPI2CS1, SPI2CS2, TACH0, TACH1, TACH10, TACH11, | ||||
|               TACH12, TACH13, TACH14, TACH15, TACH2, TACH3, TACH4, TACH5, | ||||
|               TACH6, TACH7, TACH8, TACH9, THRU0, THRU1, THRU2, THRU3, TXD1, | ||||
|               TXD2, TXD3, TXD4, UART10, UART11, UART12, UART13, UART6, UART7, | ||||
|               UART8, UART9, VB, VGAHS, VGAVS, WDTRST1, WDTRST2, WDTRST3, | ||||
|               WDTRST4, ] | ||||
|               SALT6, SALT7, SALT8, SALT9, SD1, SD2, SGPM1, SGPS1, SIOONCTRL, | ||||
|               SIOPBI, SIOPBO, SIOPWREQ, SIOPWRGD, SIOS3, SIOS5, SIOSCI, SPI1, | ||||
|               SPI1ABR, SPI1CS1, SPI1WP, SPI2, SPI2CS1, SPI2CS2, TACH0, TACH1, | ||||
|               TACH10, TACH11, TACH12, TACH13, TACH14, TACH15, TACH2, TACH3, | ||||
|               TACH4, TACH5, TACH6, TACH7, TACH8, TACH9, THRU0, THRU1, THRU2, | ||||
|               THRU3, TXD1, TXD2, TXD3, TXD4, UART10, UART11, UART12, UART13, | ||||
|               UART6, UART7, UART8, UART9, VB, VGAHS, VGAVS, WDTRST1, WDTRST2, | ||||
|               WDTRST3, WDTRST4, ] | ||||
|         groups: | ||||
|           allOf: | ||||
|             - $ref: "/schemas/types.yaml#/definitions/string" | ||||
|             - enum: [ ADC0, ADC1, ADC10, ADC11, ADC12, ADC13, ADC14, ADC15, | ||||
|               ADC2, ADC3, ADC4, ADC5, ADC6, ADC7, ADC8, ADC9, BMCINT, ESPI, | ||||
|               ESPIALT, FSI1, FSI2, FWSPIABR, FWSPID, FWQSPID, FWSPIWP, GPIT0, | ||||
|               GPIT1, GPIT2, GPIT3, GPIT4, GPIT5, GPIT6, GPIT7, GPIU0, GPIU1, | ||||
|               GPIU2, GPIU3, GPIU4, GPIU5, GPIU6, GPIU7, HVI3C3, HVI3C4, I2C1, | ||||
|               I2C10, I2C11, I2C12, I2C13, I2C14, I2C15, I2C16, I2C2, I2C3, | ||||
|               I2C4, I2C5, I2C6, I2C7, I2C8, I2C9, I3C3, I3C4, I3C5, I3C6, | ||||
|               JTAGM, LHPD, LHSIRQ, LPC, LPCHC, LPCPD, LPCPME, LPCSMI, LSIRQ, | ||||
|               MACLINK1, MACLINK2, MACLINK3, MACLINK4, MDIO1, MDIO2, MDIO3, | ||||
|               MDIO4, NCTS1, NCTS2, NCTS3, NCTS4, NDCD1, NDCD2, NDCD3, NDCD4, | ||||
|               NDSR1, NDSR2, NDSR3, NDSR4, NDTR1, NDTR2, NDTR3, NDTR4, NRI1, | ||||
|               NRI2, NRI3, NRI4, NRTS1, NRTS2, NRTS3, NRTS4, OSCCLK, PEWAKE, | ||||
|               PWM0, PWM1, PWM10G0, PWM10G1, PWM11G0, PWM11G1, PWM12G0, PWM12G1, | ||||
|               PWM13G0, PWM13G1, PWM14G0, PWM14G1, PWM15G0, PWM15G1, PWM2, PWM3, | ||||
|               PWM4, PWM5, PWM6, PWM7, PWM8G0, PWM8G1, PWM9G0, PWM9G1, QSPI1, | ||||
|               QSPI2, RGMII1, RGMII2, RGMII3, RGMII4, RMII1, RMII2, RMII3, | ||||
|               RMII4, RXD1, RXD2, RXD3, RXD4, SALT1, SALT10G0, SALT10G1, | ||||
|               SALT11G0, SALT11G1, SALT12G0, SALT12G1, SALT13G0, SALT13G1, | ||||
|               SALT14G0, SALT14G1, SALT15G0, SALT15G1, SALT16G0, SALT16G1, | ||||
|               SALT2, SALT3, SALT4, SALT5, SALT6, SALT7, SALT8, SALT9G0, | ||||
|               SALT9G1, SD1, SD2, SD3, SD3DAT4, SD3DAT5, SD3DAT6, SD3DAT7, | ||||
|               SGPM1, SGPS1, SIOONCTRL, SIOPBI, SIOPBO, SIOPWREQ, SIOPWRGD, | ||||
|               SIOS3, SIOS5, SIOSCI, SPI1, SPI1ABR, SPI1CS1, SPI1WP, SPI2, | ||||
|               SPI2CS1, SPI2CS2, TACH0, TACH1, TACH10, TACH11, TACH12, TACH13, | ||||
|               TACH14, TACH15, TACH2, TACH3, TACH4, TACH5, TACH6, TACH7, TACH8, | ||||
|               TACH9, THRU0, THRU1, THRU2, THRU3, TXD1, TXD2, TXD3, TXD4, | ||||
|               UART10, UART11, UART12G0, UART12G1, UART13G0, UART13G1, UART6, | ||||
|               UART7, UART8, UART9, VB, VGAHS, VGAVS, WDTRST1, WDTRST2, WDTRST3, | ||||
|               WDTRST4, ] | ||||
|               ADC2, ADC3, ADC4, ADC5, ADC6, ADC7, ADC8, ADC9, BMCINT, EMMCG1, | ||||
|               EMMCG4, EMMCG8, ESPI, ESPIALT, FSI1, FSI2, FWSPIABR, FWSPID, | ||||
|               FWQSPID, FWSPIWP, GPIT0, GPIT1, GPIT2, GPIT3, GPIT4, GPIT5, | ||||
|               GPIT6, GPIT7, GPIU0, GPIU1, GPIU2, GPIU3, GPIU4, GPIU5, GPIU6, | ||||
|               GPIU7, HVI3C3, HVI3C4, I2C1, I2C10, I2C11, I2C12, I2C13, I2C14, | ||||
|               I2C15, I2C16, I2C2, I2C3, I2C4, I2C5, I2C6, I2C7, I2C8, I2C9, | ||||
|               I3C3, I3C4, I3C5, I3C6, JTAGM, LHPD, LHSIRQ, LPC, LPCHC, LPCPD, | ||||
|               LPCPME, LPCSMI, LSIRQ, MACLINK1, MACLINK2, MACLINK3, MACLINK4, | ||||
|               MDIO1, MDIO2, MDIO3, MDIO4, NCTS1, NCTS2, NCTS3, NCTS4, NDCD1, | ||||
|               NDCD2, NDCD3, NDCD4, NDSR1, NDSR2, NDSR3, NDSR4, NDTR1, NDTR2, | ||||
|               NDTR3, NDTR4, NRI1, NRI2, NRI3, NRI4, NRTS1, NRTS2, NRTS3, NRTS4, | ||||
|               OSCCLK, PEWAKE, PWM0, PWM1, PWM10G0, PWM10G1, PWM11G0, PWM11G1, | ||||
|               PWM12G0, PWM12G1, PWM13G0, PWM13G1, PWM14G0, PWM14G1, PWM15G0, | ||||
|               PWM15G1, PWM2, PWM3, PWM4, PWM5, PWM6, PWM7, PWM8G0, PWM8G1, | ||||
|               PWM9G0, PWM9G1, QSPI1, QSPI2, RGMII1, RGMII2, RGMII3, RGMII4, | ||||
|               RMII1, RMII2, RMII3, RMII4, RXD1, RXD2, RXD3, RXD4, SALT1, | ||||
|               SALT10G0, SALT10G1, SALT11G0, SALT11G1, SALT12G0, SALT12G1, | ||||
|               SALT13G0, SALT13G1, SALT14G0, SALT14G1, SALT15G0, SALT15G1, | ||||
|               SALT16G0, SALT16G1, SALT2, SALT3, SALT4, SALT5, SALT6, SALT7, | ||||
|               SALT8, SALT9G0, SALT9G1, SD1, SD2, SD3, SGPM1, SGPS1, SIOONCTRL, | ||||
|               SIOPBI, SIOPBO, SIOPWREQ, SIOPWRGD, SIOS3, SIOS5, SIOSCI, SPI1, | ||||
|               SPI1ABR, SPI1CS1, SPI1WP, SPI2, SPI2CS1, SPI2CS2, TACH0, TACH1, | ||||
|               TACH10, TACH11, TACH12, TACH13, TACH14, TACH15, TACH2, TACH3, | ||||
|               TACH4, TACH5, TACH6, TACH7, TACH8, TACH9, THRU0, THRU1, THRU2, | ||||
|               THRU3, TXD1, TXD2, TXD3, TXD4, UART10, UART11, UART12G0, | ||||
|               UART12G1, UART13G0, UART13G1, UART6, UART7, UART8, UART9, VB, | ||||
|               VGAHS, VGAVS, WDTRST1, WDTRST2, WDTRST3, WDTRST4, ] | ||||
|  | ||||
| required: | ||||
|   - compatible | ||||
|   | ||||
| @@ -30,8 +30,8 @@ if: | ||||
| properties: | ||||
|   compatible: | ||||
|     enum: | ||||
|       - const: regulator-fixed | ||||
|       - const: regulator-fixed-clock | ||||
|       - regulator-fixed | ||||
|       - regulator-fixed-clock | ||||
|  | ||||
|   regulator-name: true | ||||
|  | ||||
|   | ||||
| @@ -24,15 +24,17 @@ description: | | ||||
|  | ||||
| properties: | ||||
|   compatible: | ||||
|     items: | ||||
|       - enum: | ||||
|           - sifive,rocket0 | ||||
|           - sifive,e5 | ||||
|           - sifive,e51 | ||||
|           - sifive,u54-mc | ||||
|           - sifive,u54 | ||||
|           - sifive,u5 | ||||
|       - const: riscv | ||||
|     oneOf: | ||||
|       - items: | ||||
|           - enum: | ||||
|               - sifive,rocket0 | ||||
|               - sifive,e5 | ||||
|               - sifive,e51 | ||||
|               - sifive,u54-mc | ||||
|               - sifive,u54 | ||||
|               - sifive,u5 | ||||
|           - const: riscv | ||||
|       - const: riscv    # Simulator only | ||||
|     description: | ||||
|       Identifies that the hart uses the RISC-V instruction set | ||||
|       and identifies the type of the hart. | ||||
| @@ -66,12 +68,8 @@ properties: | ||||
|       insensitive, letters in the riscv,isa string must be all | ||||
|       lowercase to simplify parsing. | ||||
|  | ||||
|   timebase-frequency: | ||||
|     type: integer | ||||
|     minimum: 1 | ||||
|     description: | ||||
|       Specifies the clock frequency of the system timer in Hz. | ||||
|       This value is common to all harts on a single system image. | ||||
|   # RISC-V requires 'timebase-frequency' in /cpus, so disallow it here | ||||
|   timebase-frequency: false | ||||
|  | ||||
|   interrupt-controller: | ||||
|     type: object | ||||
| @@ -93,7 +91,6 @@ properties: | ||||
|  | ||||
| required: | ||||
|   - riscv,isa | ||||
|   - timebase-frequency | ||||
|   - interrupt-controller | ||||
|  | ||||
| examples: | ||||
|   | ||||
| @@ -36,8 +36,10 @@ Support | ||||
| ======= | ||||
| For general Linux networking support, please use the netdev mailing | ||||
| list, which is monitored by Pensando personnel:: | ||||
|  | ||||
|   netdev@vger.kernel.org | ||||
|  | ||||
| For more specific support needs, please use the Pensando driver support | ||||
| email:: | ||||
| 	drivers@pensando.io | ||||
|  | ||||
|   drivers@pensando.io | ||||
|   | ||||
| @@ -92,16 +92,16 @@ under some conditions. | ||||
| Part III: Registering a Network Device to DIM | ||||
| ============================================== | ||||
|  | ||||
| Net DIM API exposes the main function net_dim(struct net_dim *dim, | ||||
| struct net_dim_sample end_sample). This function is the entry point to the Net | ||||
| Net DIM API exposes the main function net_dim(struct dim *dim, | ||||
| struct dim_sample end_sample). This function is the entry point to the Net | ||||
| DIM algorithm and has to be called every time the driver would like to check if | ||||
| it should change interrupt moderation parameters. The driver should provide two | ||||
| data structures: struct net_dim and struct net_dim_sample. Struct net_dim | ||||
| data structures: struct dim and struct dim_sample. Struct dim | ||||
| describes the state of DIM for a specific object (RX queue, TX queue, | ||||
| other queues, etc.). This includes the current selected profile, previous data | ||||
| samples, the callback function provided by the driver and more. | ||||
| Struct net_dim_sample describes a data sample, which will be compared to the | ||||
| data sample stored in struct net_dim in order to decide on the algorithm's next | ||||
| Struct dim_sample describes a data sample, which will be compared to the | ||||
| data sample stored in struct dim in order to decide on the algorithm's next | ||||
| step. The sample should include bytes, packets and interrupts, measured by | ||||
| the driver. | ||||
|  | ||||
| @@ -110,9 +110,9 @@ main net_dim() function. The recommended method is to call net_dim() on each | ||||
| interrupt. Since Net DIM has a built-in moderation and it might decide to skip | ||||
| iterations under certain conditions, there is no need to moderate the net_dim() | ||||
| calls as well. As mentioned above, the driver needs to provide an object of type | ||||
| struct net_dim to the net_dim() function call. It is advised for each entity | ||||
| using Net DIM to hold a struct net_dim as part of its data structure and use it | ||||
| as the main Net DIM API object. The struct net_dim_sample should hold the latest | ||||
| struct dim to the net_dim() function call. It is advised for each entity | ||||
| using Net DIM to hold a struct dim as part of its data structure and use it | ||||
| as the main Net DIM API object. The struct dim_sample should hold the latest | ||||
| bytes, packets and interrupts count. No need to perform any calculations, just | ||||
| include the raw data. | ||||
|  | ||||
| @@ -132,19 +132,19 @@ usage is not complete but it should make the outline of the usage clear. | ||||
|  | ||||
| my_driver.c: | ||||
|  | ||||
| #include <linux/net_dim.h> | ||||
| #include <linux/dim.h> | ||||
|  | ||||
| /* Callback for net DIM to schedule on a decision to change moderation */ | ||||
| void my_driver_do_dim_work(struct work_struct *work) | ||||
| { | ||||
| 	/* Get struct net_dim from struct work_struct */ | ||||
| 	struct net_dim *dim = container_of(work, struct net_dim, | ||||
| 					   work); | ||||
| 	/* Get struct dim from struct work_struct */ | ||||
| 	struct dim *dim = container_of(work, struct dim, | ||||
| 				       work); | ||||
| 	/* Do interrupt moderation related stuff */ | ||||
| 	... | ||||
|  | ||||
| 	/* Signal net DIM work is done and it should move to next iteration */ | ||||
| 	dim->state = NET_DIM_START_MEASURE; | ||||
| 	dim->state = DIM_START_MEASURE; | ||||
| } | ||||
|  | ||||
| /* My driver's interrupt handler */ | ||||
| @@ -152,13 +152,13 @@ int my_driver_handle_interrupt(struct my_driver_entity *my_entity, ...) | ||||
| { | ||||
| 	... | ||||
| 	/* A struct to hold current measured data */ | ||||
| 	struct net_dim_sample dim_sample; | ||||
| 	struct dim_sample dim_sample; | ||||
| 	... | ||||
| 	/* Initiate data sample struct with current data */ | ||||
| 	net_dim_sample(my_entity->events, | ||||
| 		       my_entity->packets, | ||||
| 		       my_entity->bytes, | ||||
| 		       &dim_sample); | ||||
| 	dim_update_sample(my_entity->events, | ||||
| 		          my_entity->packets, | ||||
| 		          my_entity->bytes, | ||||
| 		          &dim_sample); | ||||
| 	/* Call net DIM */ | ||||
| 	net_dim(&my_entity->dim, dim_sample); | ||||
| 	... | ||||
|   | ||||
							
								
								
									
										30
									
								
								MAINTAINERS
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								MAINTAINERS
									
									
									
									
									
								
							| @@ -2323,11 +2323,13 @@ F:	drivers/edac/altera_edac. | ||||
|  | ||||
| ARM/SPREADTRUM SoC SUPPORT | ||||
| M:	Orson Zhai <orsonzhai@gmail.com> | ||||
| M:	Baolin Wang <baolin.wang@linaro.org> | ||||
| M:	Baolin Wang <baolin.wang7@gmail.com> | ||||
| M:	Chunyan Zhang <zhang.lyra@gmail.com> | ||||
| S:	Maintained | ||||
| F:	arch/arm64/boot/dts/sprd | ||||
| N:	sprd | ||||
| N:	sc27xx | ||||
| N:	sc2731 | ||||
|  | ||||
| ARM/STI ARCHITECTURE | ||||
| M:	Patrice Chotard <patrice.chotard@st.com> | ||||
| @@ -3096,7 +3098,7 @@ S:	Supported | ||||
| F:	arch/arm64/net/ | ||||
|  | ||||
| BPF JIT for MIPS (32-BIT AND 64-BIT) | ||||
| M:	Paul Burton <paul.burton@mips.com> | ||||
| M:	Paul Burton <paulburton@kernel.org> | ||||
| L:	netdev@vger.kernel.org | ||||
| L:	bpf@vger.kernel.org | ||||
| S:	Maintained | ||||
| @@ -3183,7 +3185,7 @@ N:	bcm216* | ||||
| N:	kona | ||||
| F:	arch/arm/mach-bcm/ | ||||
|  | ||||
| BROADCOM BCM2835 ARM ARCHITECTURE | ||||
| BROADCOM BCM2711/BCM2835 ARM ARCHITECTURE | ||||
| M:	Eric Anholt <eric@anholt.net> | ||||
| M:	Stefan Wahren <wahrenst@gmx.net> | ||||
| L:	bcm-kernel-feedback-list@broadcom.com | ||||
| @@ -3191,6 +3193,7 @@ L:	linux-rpi-kernel@lists.infradead.org (moderated for non-subscribers) | ||||
| L:	linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) | ||||
| T:	git git://github.com/anholt/linux | ||||
| S:	Maintained | ||||
| N:	bcm2711 | ||||
| N:	bcm2835 | ||||
| F:	drivers/staging/vc04_services | ||||
|  | ||||
| @@ -3237,8 +3240,6 @@ S:	Maintained | ||||
| F:	drivers/usb/gadget/udc/bcm63xx_udc.* | ||||
|  | ||||
| BROADCOM BCM7XXX ARM ARCHITECTURE | ||||
| M:	Brian Norris <computersforpeace@gmail.com> | ||||
| M:	Gregory Fong <gregory.0xf0@gmail.com> | ||||
| M:	Florian Fainelli <f.fainelli@gmail.com> | ||||
| M:	bcm-kernel-feedback-list@broadcom.com | ||||
| L:	linux-arm-kernel@lists.infradead.org (moderated for non-subscribers) | ||||
| @@ -8001,7 +8002,7 @@ S:	Maintained | ||||
| F:	drivers/usb/atm/ueagle-atm.c | ||||
|  | ||||
| IMGTEC ASCII LCD DRIVER | ||||
| M:	Paul Burton <paul.burton@mips.com> | ||||
| M:	Paul Burton <paulburton@kernel.org> | ||||
| S:	Maintained | ||||
| F:	Documentation/devicetree/bindings/auxdisplay/img-ascii-lcd.txt | ||||
| F:	drivers/auxdisplay/img-ascii-lcd.c | ||||
| @@ -9122,7 +9123,7 @@ F:	drivers/auxdisplay/ks0108.c | ||||
| F:	include/linux/ks0108.h | ||||
|  | ||||
| L3MDEV | ||||
| M:	David Ahern <dsa@cumulusnetworks.com> | ||||
| M:	David Ahern <dsahern@kernel.org> | ||||
| L:	netdev@vger.kernel.org | ||||
| S:	Maintained | ||||
| F:	net/l3mdev | ||||
| @@ -10255,7 +10256,7 @@ MEDIATEK ETHERNET DRIVER | ||||
| M:	Felix Fietkau <nbd@openwrt.org> | ||||
| M:	John Crispin <john@phrozen.org> | ||||
| M:	Sean Wang <sean.wang@mediatek.com> | ||||
| M:	Nelson Chang <nelson.chang@mediatek.com> | ||||
| M:	Mark Lee <Mark-MC.Lee@mediatek.com> | ||||
| L:	netdev@vger.kernel.org | ||||
| S:	Maintained | ||||
| F:	drivers/net/ethernet/mediatek/ | ||||
| @@ -10828,7 +10829,7 @@ F:	drivers/usb/image/microtek.* | ||||
|  | ||||
| MIPS | ||||
| M:	Ralf Baechle <ralf@linux-mips.org> | ||||
| M:	Paul Burton <paul.burton@mips.com> | ||||
| M:	Paul Burton <paulburton@kernel.org> | ||||
| M:	James Hogan <jhogan@kernel.org> | ||||
| L:	linux-mips@vger.kernel.org | ||||
| W:	http://www.linux-mips.org/ | ||||
| @@ -10842,7 +10843,7 @@ F:	arch/mips/ | ||||
| F:	drivers/platform/mips/ | ||||
|  | ||||
| MIPS BOSTON DEVELOPMENT BOARD | ||||
| M:	Paul Burton <paul.burton@mips.com> | ||||
| M:	Paul Burton <paulburton@kernel.org> | ||||
| L:	linux-mips@vger.kernel.org | ||||
| S:	Maintained | ||||
| F:	Documentation/devicetree/bindings/clock/img,boston-clock.txt | ||||
| @@ -10852,7 +10853,7 @@ F:	drivers/clk/imgtec/clk-boston.c | ||||
| F:	include/dt-bindings/clock/boston-clock.h | ||||
|  | ||||
| MIPS GENERIC PLATFORM | ||||
| M:	Paul Burton <paul.burton@mips.com> | ||||
| M:	Paul Burton <paulburton@kernel.org> | ||||
| L:	linux-mips@vger.kernel.org | ||||
| S:	Supported | ||||
| F:	Documentation/devicetree/bindings/power/mti,mips-cpc.txt | ||||
| @@ -12312,12 +12313,15 @@ F:	arch/parisc/ | ||||
| F:	Documentation/parisc/ | ||||
| F:	drivers/parisc/ | ||||
| F:	drivers/char/agp/parisc-agp.c | ||||
| F:	drivers/input/misc/hp_sdc_rtc.c | ||||
| F:	drivers/input/serio/gscps2.c | ||||
| F:	drivers/input/serio/hp_sdc* | ||||
| F:	drivers/parport/parport_gsc.* | ||||
| F:	drivers/tty/serial/8250/8250_gsc.c | ||||
| F:	drivers/video/fbdev/sti* | ||||
| F:	drivers/video/console/sti* | ||||
| F:	drivers/video/logo/logo_parisc* | ||||
| F:	include/linux/hp_sdc.h | ||||
|  | ||||
| PARMAN | ||||
| M:	Jiri Pirko <jiri@mellanox.com> | ||||
| @@ -13368,7 +13372,7 @@ S:	Maintained | ||||
| F:	drivers/scsi/qla1280.[ch] | ||||
|  | ||||
| QLOGIC QLA2XXX FC-SCSI DRIVER | ||||
| M:	qla2xxx-upstream@qlogic.com | ||||
| M:	hmadhani@marvell.com | ||||
| L:	linux-scsi@vger.kernel.org | ||||
| S:	Supported | ||||
| F:	Documentation/scsi/LICENSE.qla2xxx | ||||
| @@ -17437,7 +17441,7 @@ F:	include/linux/regulator/ | ||||
| K:	regulator_get_optional | ||||
|  | ||||
| VRF | ||||
| M:	David Ahern <dsa@cumulusnetworks.com> | ||||
| M:	David Ahern <dsahern@kernel.org> | ||||
| M:	Shrijeet Mukherjee <shrijeet@gmail.com> | ||||
| L:	netdev@vger.kernel.org | ||||
| S:	Maintained | ||||
|   | ||||
							
								
								
									
										6
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								Makefile
									
									
									
									
									
								
							| @@ -2,8 +2,8 @@ | ||||
| VERSION = 5 | ||||
| PATCHLEVEL = 4 | ||||
| SUBLEVEL = 0 | ||||
| EXTRAVERSION = -rc3 | ||||
| NAME = Nesting Opossum | ||||
| EXTRAVERSION = -rc5 | ||||
| NAME = Kleptomaniac Octopus | ||||
|  | ||||
| # *DOCUMENTATION* | ||||
| # To see a list of typical targets execute "make help" | ||||
| @@ -1037,7 +1037,7 @@ export KBUILD_VMLINUX_OBJS := $(head-y) $(init-y) $(core-y) $(libs-y2) \ | ||||
| export KBUILD_VMLINUX_LIBS := $(libs-y1) | ||||
| export KBUILD_LDS          := arch/$(SRCARCH)/kernel/vmlinux.lds | ||||
| export LDFLAGS_vmlinux | ||||
| # used by scripts/package/Makefile | ||||
| # used by scripts/Makefile.package | ||||
| export KBUILD_ALLDIRS := $(sort $(filter-out arch/%,$(vmlinux-alldirs)) LICENSES arch include scripts tools) | ||||
|  | ||||
| vmlinux-deps := $(KBUILD_LDS) $(KBUILD_VMLINUX_OBJS) $(KBUILD_VMLINUX_LIBS) | ||||
|   | ||||
| @@ -111,13 +111,13 @@ | ||||
| 		reg = <0x70>; | ||||
| 		#address-cells = <1>; | ||||
| 		#size-cells = <0>; | ||||
| 		i2c-mux-idle-disconnect; | ||||
|  | ||||
| 		i2c@0 { | ||||
| 			/* FMC A */ | ||||
| 			#address-cells = <1>; | ||||
| 			#size-cells = <0>; | ||||
| 			reg = <0>; | ||||
| 			i2c-mux-idle-disconnect; | ||||
| 		}; | ||||
|  | ||||
| 		i2c@1 { | ||||
| @@ -125,7 +125,6 @@ | ||||
| 			#address-cells = <1>; | ||||
| 			#size-cells = <0>; | ||||
| 			reg = <1>; | ||||
| 			i2c-mux-idle-disconnect; | ||||
| 		}; | ||||
|  | ||||
| 		i2c@2 { | ||||
| @@ -133,7 +132,6 @@ | ||||
| 			#address-cells = <1>; | ||||
| 			#size-cells = <0>; | ||||
| 			reg = <2>; | ||||
| 			i2c-mux-idle-disconnect; | ||||
| 		}; | ||||
|  | ||||
| 		i2c@3 { | ||||
| @@ -141,7 +139,6 @@ | ||||
| 			#address-cells = <1>; | ||||
| 			#size-cells = <0>; | ||||
| 			reg = <3>; | ||||
| 			i2c-mux-idle-disconnect; | ||||
| 		}; | ||||
|  | ||||
| 		i2c@4 { | ||||
| @@ -149,14 +146,12 @@ | ||||
| 			#address-cells = <1>; | ||||
| 			#size-cells = <0>; | ||||
| 			reg = <4>; | ||||
| 			i2c-mux-idle-disconnect; | ||||
| 		}; | ||||
|  | ||||
| 		i2c@5 { | ||||
| 			#address-cells = <1>; | ||||
| 			#size-cells = <0>; | ||||
| 			reg = <5>; | ||||
| 			i2c-mux-idle-disconnect; | ||||
|  | ||||
| 			ina230@40 { compatible = "ti,ina230"; reg = <0x40>; shunt-resistor = <5000>; }; | ||||
| 			ina230@41 { compatible = "ti,ina230"; reg = <0x41>; shunt-resistor = <5000>; }; | ||||
| @@ -182,14 +177,12 @@ | ||||
| 			#address-cells = <1>; | ||||
| 			#size-cells = <0>; | ||||
| 			reg = <6>; | ||||
| 			i2c-mux-idle-disconnect; | ||||
| 		}; | ||||
|  | ||||
| 		i2c@7 { | ||||
| 			#address-cells = <1>; | ||||
| 			#size-cells = <0>; | ||||
| 			reg = <7>; | ||||
| 			i2c-mux-idle-disconnect; | ||||
|  | ||||
| 			u41: pca9575@20 { | ||||
| 				compatible = "nxp,pca9575"; | ||||
|   | ||||
| @@ -113,6 +113,7 @@ | ||||
| 	#address-cells = <1>; | ||||
| 	#size-cells = <0>; | ||||
| 	pinctrl-0 = <&emmc_gpio34 &gpclk2_gpio43>; | ||||
| 	bus-width = <4>; | ||||
| 	mmc-pwrseq = <&wifi_pwrseq>; | ||||
| 	non-removable; | ||||
| 	status = "okay"; | ||||
|   | ||||
| @@ -9,6 +9,14 @@ | ||||
| 		reg = <0 0x40000000>; | ||||
| 	}; | ||||
|  | ||||
| 	leds { | ||||
| 		/* | ||||
| 		 * Since there is no upstream GPIO driver yet, | ||||
| 		 * remove the incomplete node. | ||||
| 		 */ | ||||
| 		/delete-node/ act; | ||||
| 	}; | ||||
|  | ||||
| 	reg_3v3: fixed-regulator { | ||||
| 		compatible = "regulator-fixed"; | ||||
| 		regulator-name = "3V3"; | ||||
|   | ||||
| @@ -207,6 +207,10 @@ | ||||
| 	vin-supply = <&sw1c_reg>; | ||||
| }; | ||||
|  | ||||
| &snvs_poweroff { | ||||
| 	status = "okay"; | ||||
| }; | ||||
|  | ||||
| &iomuxc { | ||||
| 	pinctrl-names = "default"; | ||||
| 	pinctrl-0 = <&pinctrl_hog>; | ||||
|   | ||||
| @@ -448,7 +448,7 @@ | ||||
| 				compatible = "fsl,imx7d-gpt", "fsl,imx6sx-gpt"; | ||||
| 				reg = <0x302d0000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clks IMX7D_CLK_DUMMY>, | ||||
| 				clocks = <&clks IMX7D_GPT1_ROOT_CLK>, | ||||
| 					 <&clks IMX7D_GPT1_ROOT_CLK>; | ||||
| 				clock-names = "ipg", "per"; | ||||
| 			}; | ||||
| @@ -457,7 +457,7 @@ | ||||
| 				compatible = "fsl,imx7d-gpt", "fsl,imx6sx-gpt"; | ||||
| 				reg = <0x302e0000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clks IMX7D_CLK_DUMMY>, | ||||
| 				clocks = <&clks IMX7D_GPT2_ROOT_CLK>, | ||||
| 					 <&clks IMX7D_GPT2_ROOT_CLK>; | ||||
| 				clock-names = "ipg", "per"; | ||||
| 				status = "disabled"; | ||||
| @@ -467,7 +467,7 @@ | ||||
| 				compatible = "fsl,imx7d-gpt", "fsl,imx6sx-gpt"; | ||||
| 				reg = <0x302f0000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clks IMX7D_CLK_DUMMY>, | ||||
| 				clocks = <&clks IMX7D_GPT3_ROOT_CLK>, | ||||
| 					 <&clks IMX7D_GPT3_ROOT_CLK>; | ||||
| 				clock-names = "ipg", "per"; | ||||
| 				status = "disabled"; | ||||
| @@ -477,7 +477,7 @@ | ||||
| 				compatible = "fsl,imx7d-gpt", "fsl,imx6sx-gpt"; | ||||
| 				reg = <0x30300000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clks IMX7D_CLK_DUMMY>, | ||||
| 				clocks = <&clks IMX7D_GPT4_ROOT_CLK>, | ||||
| 					 <&clks IMX7D_GPT4_ROOT_CLK>; | ||||
| 				clock-names = "ipg", "per"; | ||||
| 				status = "disabled"; | ||||
|   | ||||
| @@ -192,3 +192,7 @@ | ||||
| &twl_gpio { | ||||
| 	ti,use-leds; | ||||
| }; | ||||
|  | ||||
| &twl_keypad { | ||||
| 	status = "disabled"; | ||||
| }; | ||||
|   | ||||
| @@ -66,9 +66,21 @@ | ||||
| 	pinctrl-1 = <&ephy_leds_pins>; | ||||
| 	status = "okay"; | ||||
|  | ||||
| 	gmac0: mac@0 { | ||||
| 		compatible = "mediatek,eth-mac"; | ||||
| 		reg = <0>; | ||||
| 		phy-mode = "2500base-x"; | ||||
| 		fixed-link { | ||||
| 			speed = <2500>; | ||||
| 			full-duplex; | ||||
| 			pause; | ||||
| 		}; | ||||
| 	}; | ||||
|  | ||||
| 	gmac1: mac@1 { | ||||
| 		compatible = "mediatek,eth-mac"; | ||||
| 		reg = <1>; | ||||
| 		phy-mode = "gmii"; | ||||
| 		phy-handle = <&phy0>; | ||||
| 	}; | ||||
|  | ||||
| @@ -78,7 +90,6 @@ | ||||
|  | ||||
| 		phy0: ethernet-phy@0 { | ||||
| 			reg = <0>; | ||||
| 			phy-mode = "gmii"; | ||||
| 		}; | ||||
| 	}; | ||||
| }; | ||||
|   | ||||
| @@ -468,14 +468,12 @@ | ||||
| 			compatible = "mediatek,mt7629-sgmiisys", "syscon"; | ||||
| 			reg = <0x1b128000 0x3000>; | ||||
| 			#clock-cells = <1>; | ||||
| 			mediatek,physpeed = "2500"; | ||||
| 		}; | ||||
|  | ||||
| 		sgmiisys1: syscon@1b130000 { | ||||
| 			compatible = "mediatek,mt7629-sgmiisys", "syscon"; | ||||
| 			reg = <0x1b130000 0x3000>; | ||||
| 			#clock-cells = <1>; | ||||
| 			mediatek,physpeed = "2500"; | ||||
| 		}; | ||||
| 	}; | ||||
| }; | ||||
|   | ||||
| @@ -369,7 +369,7 @@ | ||||
| 		compatible = "ti,wl1285", "ti,wl1283"; | ||||
| 		reg = <2>; | ||||
| 		/* gpio_100 with gpmc_wait2 pad as wakeirq */ | ||||
| 		interrupts-extended = <&gpio4 4 IRQ_TYPE_EDGE_RISING>, | ||||
| 		interrupts-extended = <&gpio4 4 IRQ_TYPE_LEVEL_HIGH>, | ||||
| 				      <&omap4_pmx_core 0x4e>; | ||||
| 		interrupt-names = "irq", "wakeup"; | ||||
| 		ref-clock-frequency = <26000000>; | ||||
|   | ||||
| @@ -474,7 +474,7 @@ | ||||
| 		compatible = "ti,wl1271"; | ||||
| 		reg = <2>; | ||||
| 		/* gpio_53 with gpmc_ncs3 pad as wakeup */ | ||||
| 		interrupts-extended = <&gpio2 21 IRQ_TYPE_EDGE_RISING>, | ||||
| 		interrupts-extended = <&gpio2 21 IRQ_TYPE_LEVEL_HIGH>, | ||||
| 				      <&omap4_pmx_core 0x3a>; | ||||
| 		interrupt-names = "irq", "wakeup"; | ||||
| 		ref-clock-frequency = <38400000>; | ||||
|   | ||||
| @@ -512,7 +512,7 @@ | ||||
| 		compatible = "ti,wl1281"; | ||||
| 		reg = <2>; | ||||
| 		interrupt-parent = <&gpio1>; | ||||
| 		interrupts = <21 IRQ_TYPE_EDGE_RISING>; /* gpio 53 */ | ||||
| 		interrupts = <21 IRQ_TYPE_LEVEL_HIGH>; /* gpio 53 */ | ||||
| 		ref-clock-frequency = <26000000>; | ||||
| 		tcxo-clock-frequency = <26000000>; | ||||
| 	}; | ||||
|   | ||||
| @@ -69,7 +69,7 @@ | ||||
| 		compatible = "ti,wl1271"; | ||||
| 		reg = <2>; | ||||
| 		interrupt-parent = <&gpio2>; | ||||
| 		interrupts = <9 IRQ_TYPE_EDGE_RISING>; /* gpio 41 */ | ||||
| 		interrupts = <9 IRQ_TYPE_LEVEL_HIGH>; /* gpio 41 */ | ||||
| 		ref-clock-frequency = <38400000>; | ||||
| 	}; | ||||
| }; | ||||
|   | ||||
| @@ -362,7 +362,7 @@ | ||||
| 		pinctrl-names = "default"; | ||||
| 		pinctrl-0 = <&wlcore_irq_pin>; | ||||
| 		interrupt-parent = <&gpio1>; | ||||
| 		interrupts = <14 IRQ_TYPE_EDGE_RISING>;	/* gpio 14 */ | ||||
| 		interrupts = <14 IRQ_TYPE_LEVEL_HIGH>;	/* gpio 14 */ | ||||
| 		ref-clock-frequency = <26000000>; | ||||
| 	}; | ||||
| }; | ||||
|   | ||||
| @@ -1146,7 +1146,7 @@ | ||||
| 		}; | ||||
| 	}; | ||||
|  | ||||
| 	gpu_cm: clock-controller@1500 { | ||||
| 	gpu_cm: gpu_cm@1500 { | ||||
| 		compatible = "ti,omap4-cm"; | ||||
| 		reg = <0x1500 0x100>; | ||||
| 		#address-cells = <1>; | ||||
|   | ||||
| @@ -609,13 +609,13 @@ | ||||
| 						 <STM32_PINMUX('F', 6, AF9)>; /* QSPI_BK1_IO3 */ | ||||
| 					bias-disable; | ||||
| 					drive-push-pull; | ||||
| 					slew-rate = <3>; | ||||
| 					slew-rate = <1>; | ||||
| 				}; | ||||
| 				pins2 { | ||||
| 					pinmux = <STM32_PINMUX('B', 6, AF10)>; /* QSPI_BK1_NCS */ | ||||
| 					bias-pull-up; | ||||
| 					drive-push-pull; | ||||
| 					slew-rate = <3>; | ||||
| 					slew-rate = <1>; | ||||
| 				}; | ||||
| 			}; | ||||
|  | ||||
| @@ -637,13 +637,13 @@ | ||||
| 						 <STM32_PINMUX('G', 7, AF11)>; /* QSPI_BK2_IO3 */ | ||||
| 					bias-disable; | ||||
| 					drive-push-pull; | ||||
| 					slew-rate = <3>; | ||||
| 					slew-rate = <1>; | ||||
| 				}; | ||||
| 				pins2 { | ||||
| 					pinmux = <STM32_PINMUX('C', 0, AF10)>; /* QSPI_BK2_NCS */ | ||||
| 					bias-pull-up; | ||||
| 					drive-push-pull; | ||||
| 					slew-rate = <3>; | ||||
| 					slew-rate = <1>; | ||||
| 				}; | ||||
| 			}; | ||||
|  | ||||
|   | ||||
| @@ -380,9 +380,8 @@ | ||||
| 			compatible = "allwinner,sun7i-a20-csi0"; | ||||
| 			reg = <0x01c09000 0x1000>; | ||||
| 			interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 			clocks = <&ccu CLK_AHB_CSI0>, <&ccu CLK_CSI0>, | ||||
| 				 <&ccu CLK_CSI_SCLK>, <&ccu CLK_DRAM_CSI0>; | ||||
| 			clock-names = "bus", "mod", "isp", "ram"; | ||||
| 			clocks = <&ccu CLK_AHB_CSI0>, <&ccu CLK_CSI_SCLK>, <&ccu CLK_DRAM_CSI0>; | ||||
| 			clock-names = "bus", "isp", "ram"; | ||||
| 			resets = <&ccu RST_CSI0>; | ||||
| 			status = "disabled"; | ||||
| 		}; | ||||
|   | ||||
| @@ -602,6 +602,7 @@ | ||||
| 		#address-cells = <1>; | ||||
| 		#size-cells = <0>; | ||||
| 		reg = <0x70>; | ||||
| 		i2c-mux-idle-disconnect; | ||||
|  | ||||
| 		sff0_i2c: i2c@1 { | ||||
| 			#address-cells = <1>; | ||||
| @@ -640,6 +641,7 @@ | ||||
| 		reg = <0x71>; | ||||
| 		#address-cells = <1>; | ||||
| 		#size-cells = <0>; | ||||
| 		i2c-mux-idle-disconnect; | ||||
|  | ||||
| 		sff5_i2c: i2c@1 { | ||||
| 			#address-cells = <1>; | ||||
|   | ||||
| @@ -167,6 +167,7 @@ CONFIG_FB=y | ||||
| CONFIG_FIRMWARE_EDID=y | ||||
| CONFIG_FB_DA8XX=y | ||||
| CONFIG_BACKLIGHT_PWM=m | ||||
| CONFIG_BACKLIGHT_GPIO=m | ||||
| CONFIG_FRAMEBUFFER_CONSOLE=y | ||||
| CONFIG_LOGO=y | ||||
| CONFIG_SOUND=m | ||||
|   | ||||
| @@ -276,6 +276,7 @@ CONFIG_VIDEO_OV5640=m | ||||
| CONFIG_VIDEO_OV5645=m | ||||
| CONFIG_IMX_IPUV3_CORE=y | ||||
| CONFIG_DRM=y | ||||
| CONFIG_DRM_MSM=y | ||||
| CONFIG_DRM_PANEL_LVDS=y | ||||
| CONFIG_DRM_PANEL_SIMPLE=y | ||||
| CONFIG_DRM_PANEL_SEIKO_43WVF1G=y | ||||
|   | ||||
| @@ -356,15 +356,15 @@ CONFIG_DRM_OMAP_CONNECTOR_HDMI=m | ||||
| CONFIG_DRM_OMAP_CONNECTOR_ANALOG_TV=m | ||||
| CONFIG_DRM_OMAP_PANEL_DPI=m | ||||
| CONFIG_DRM_OMAP_PANEL_DSI_CM=m | ||||
| CONFIG_DRM_OMAP_PANEL_SONY_ACX565AKM=m | ||||
| CONFIG_DRM_OMAP_PANEL_LGPHILIPS_LB035Q02=m | ||||
| CONFIG_DRM_OMAP_PANEL_SHARP_LS037V7DW01=m | ||||
| CONFIG_DRM_OMAP_PANEL_TPO_TD028TTEC1=m | ||||
| CONFIG_DRM_OMAP_PANEL_TPO_TD043MTEA1=m | ||||
| CONFIG_DRM_OMAP_PANEL_NEC_NL8048HL11=m | ||||
| CONFIG_DRM_TILCDC=m | ||||
| CONFIG_DRM_PANEL_SIMPLE=m | ||||
| CONFIG_DRM_TI_TFP410=m | ||||
| CONFIG_DRM_PANEL_LG_LB035Q02=m | ||||
| CONFIG_DRM_PANEL_NEC_NL8048HL11=m | ||||
| CONFIG_DRM_PANEL_SHARP_LS037V7DW01=m | ||||
| CONFIG_DRM_PANEL_SONY_ACX565AKM=m | ||||
| CONFIG_DRM_PANEL_TPO_TD028TTEC1=m | ||||
| CONFIG_DRM_PANEL_TPO_TD043MTEA1=m | ||||
| CONFIG_FB=y | ||||
| CONFIG_FIRMWARE_EDID=y | ||||
| CONFIG_FB_MODE_HELPERS=y | ||||
|   | ||||
| @@ -82,7 +82,7 @@ | ||||
| #ifndef __ASSEMBLY__ | ||||
| 
 | ||||
| #ifdef CONFIG_CPU_CP15_MMU | ||||
| static inline unsigned int get_domain(void) | ||||
| static __always_inline unsigned int get_domain(void) | ||||
| { | ||||
| 	unsigned int domain; | ||||
| 
 | ||||
| @@ -94,7 +94,7 @@ static inline unsigned int get_domain(void) | ||||
| 	return domain; | ||||
| } | ||||
| 
 | ||||
| static inline void set_domain(unsigned val) | ||||
| static __always_inline void set_domain(unsigned int val) | ||||
| { | ||||
| 	asm volatile( | ||||
| 	"mcr	p15, 0, %0, c3, c0	@ set domain" | ||||
| @@ -102,12 +102,12 @@ static inline void set_domain(unsigned val) | ||||
| 	isb(); | ||||
| } | ||||
| #else | ||||
| static inline unsigned int get_domain(void) | ||||
| static __always_inline unsigned int get_domain(void) | ||||
| { | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| static inline void set_domain(unsigned val) | ||||
| static __always_inline void set_domain(unsigned int val) | ||||
| { | ||||
| } | ||||
| #endif | ||||
|   | ||||
| @@ -22,7 +22,7 @@ | ||||
|  * perform such accesses (eg, via list poison values) which could then | ||||
|  * be exploited for priviledge escalation. | ||||
|  */ | ||||
| static inline unsigned int uaccess_save_and_enable(void) | ||||
| static __always_inline unsigned int uaccess_save_and_enable(void) | ||||
| { | ||||
| #ifdef CONFIG_CPU_SW_DOMAIN_PAN | ||||
| 	unsigned int old_domain = get_domain(); | ||||
| @@ -37,7 +37,7 @@ static inline unsigned int uaccess_save_and_enable(void) | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| static inline void uaccess_restore(unsigned int flags) | ||||
| static __always_inline void uaccess_restore(unsigned int flags) | ||||
| { | ||||
| #ifdef CONFIG_CPU_SW_DOMAIN_PAN | ||||
| 	/* Restore the user access mask */ | ||||
|   | ||||
| @@ -68,7 +68,7 @@ ENDPROC(__vet_atags) | ||||
|  * The following fragment of code is executed with the MMU on in MMU mode, | ||||
|  * and uses absolute addresses; this is not position independent. | ||||
|  * | ||||
|  *  r0  = cp#15 control register | ||||
|  *  r0  = cp#15 control register (exc_ret for M-class) | ||||
|  *  r1  = machine ID | ||||
|  *  r2  = atags/dtb pointer | ||||
|  *  r9  = processor ID | ||||
| @@ -137,7 +137,8 @@ __mmap_switched_data: | ||||
| #ifdef CONFIG_CPU_CP15 | ||||
| 	.long	cr_alignment			@ r3 | ||||
| #else | ||||
| 	.long	0				@ r3 | ||||
| M_CLASS(.long	exc_ret)			@ r3 | ||||
| AR_CLASS(.long	0)				@ r3 | ||||
| #endif | ||||
| 	.size	__mmap_switched_data, . - __mmap_switched_data | ||||
|  | ||||
|   | ||||
| @@ -201,6 +201,8 @@ M_CLASS(streq	r3, [r12, #PMSAv8_MAIR1]) | ||||
| 	bic	r0, r0, #V7M_SCB_CCR_IC | ||||
| #endif | ||||
| 	str	r0, [r12, V7M_SCB_CCR] | ||||
| 	/* Pass exc_ret to __mmap_switched */ | ||||
| 	mov	r0, r10 | ||||
| #endif /* CONFIG_CPU_CP15 elif CONFIG_CPU_V7M */ | ||||
| 	ret	lr | ||||
| ENDPROC(__after_proc_init) | ||||
|   | ||||
| @@ -462,8 +462,8 @@ static s8 dm365_queue_priority_mapping[][2] = { | ||||
| }; | ||||
| 
 | ||||
| static const struct dma_slave_map dm365_edma_map[] = { | ||||
| 	{ "davinci-mcbsp.0", "tx", EDMA_FILTER_PARAM(0, 2) }, | ||||
| 	{ "davinci-mcbsp.0", "rx", EDMA_FILTER_PARAM(0, 3) }, | ||||
| 	{ "davinci-mcbsp", "tx", EDMA_FILTER_PARAM(0, 2) }, | ||||
| 	{ "davinci-mcbsp", "rx", EDMA_FILTER_PARAM(0, 3) }, | ||||
| 	{ "davinci_voicecodec", "tx", EDMA_FILTER_PARAM(0, 2) }, | ||||
| 	{ "davinci_voicecodec", "rx", EDMA_FILTER_PARAM(0, 3) }, | ||||
| 	{ "spi_davinci.2", "tx", EDMA_FILTER_PARAM(0, 10) }, | ||||
|   | ||||
| @@ -89,6 +89,13 @@ static struct iommu_platform_data omap3_iommu_pdata = { | ||||
| 	.reset_name = "mmu", | ||||
| 	.assert_reset = omap_device_assert_hardreset, | ||||
| 	.deassert_reset = omap_device_deassert_hardreset, | ||||
| 	.device_enable = omap_device_enable, | ||||
| 	.device_idle = omap_device_idle, | ||||
| }; | ||||
| 
 | ||||
| static struct iommu_platform_data omap3_iommu_isp_pdata = { | ||||
| 	.device_enable = omap_device_enable, | ||||
| 	.device_idle = omap_device_idle, | ||||
| }; | ||||
| 
 | ||||
| static int omap3_sbc_t3730_twl_callback(struct device *dev, | ||||
| @@ -424,6 +431,8 @@ static struct iommu_platform_data omap4_iommu_pdata = { | ||||
| 	.reset_name = "mmu_cache", | ||||
| 	.assert_reset = omap_device_assert_hardreset, | ||||
| 	.deassert_reset = omap_device_deassert_hardreset, | ||||
| 	.device_enable = omap_device_enable, | ||||
| 	.device_idle = omap_device_idle, | ||||
| }; | ||||
| #endif | ||||
| 
 | ||||
| @@ -617,6 +626,8 @@ static struct of_dev_auxdata omap_auxdata_lookup[] = { | ||||
| #ifdef CONFIG_ARCH_OMAP3 | ||||
| 	OF_DEV_AUXDATA("ti,omap2-iommu", 0x5d000000, "5d000000.mmu", | ||||
| 		       &omap3_iommu_pdata), | ||||
| 	OF_DEV_AUXDATA("ti,omap2-iommu", 0x480bd400, "480bd400.mmu", | ||||
| 		       &omap3_iommu_isp_pdata), | ||||
| 	OF_DEV_AUXDATA("ti,omap3-smartreflex-core", 0x480cb000, | ||||
| 		       "480cb000.smartreflex", &omap_sr_pdata[OMAP_SR_CORE]), | ||||
| 	OF_DEV_AUXDATA("ti,omap3-smartreflex-mpu-iva", 0x480c9000, | ||||
|   | ||||
| @@ -324,7 +324,7 @@ union offset_union { | ||||
| 	__put32_unaligned_check("strbt", val, addr) | ||||
| 
 | ||||
| static void | ||||
| do_alignment_finish_ldst(unsigned long addr, unsigned long instr, struct pt_regs *regs, union offset_union offset) | ||||
| do_alignment_finish_ldst(unsigned long addr, u32 instr, struct pt_regs *regs, union offset_union offset) | ||||
| { | ||||
| 	if (!LDST_U_BIT(instr)) | ||||
| 		offset.un = -offset.un; | ||||
| @@ -337,7 +337,7 @@ do_alignment_finish_ldst(unsigned long addr, unsigned long instr, struct pt_regs | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| do_alignment_ldrhstrh(unsigned long addr, unsigned long instr, struct pt_regs *regs) | ||||
| do_alignment_ldrhstrh(unsigned long addr, u32 instr, struct pt_regs *regs) | ||||
| { | ||||
| 	unsigned int rd = RD_BITS(instr); | ||||
| 
 | ||||
| @@ -386,8 +386,7 @@ do_alignment_ldrhstrh(unsigned long addr, unsigned long instr, struct pt_regs *r | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| do_alignment_ldrdstrd(unsigned long addr, unsigned long instr, | ||||
| 		      struct pt_regs *regs) | ||||
| do_alignment_ldrdstrd(unsigned long addr, u32 instr, struct pt_regs *regs) | ||||
| { | ||||
| 	unsigned int rd = RD_BITS(instr); | ||||
| 	unsigned int rd2; | ||||
| @@ -449,7 +448,7 @@ do_alignment_ldrdstrd(unsigned long addr, unsigned long instr, | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| do_alignment_ldrstr(unsigned long addr, unsigned long instr, struct pt_regs *regs) | ||||
| do_alignment_ldrstr(unsigned long addr, u32 instr, struct pt_regs *regs) | ||||
| { | ||||
| 	unsigned int rd = RD_BITS(instr); | ||||
| 
 | ||||
| @@ -498,7 +497,7 @@ do_alignment_ldrstr(unsigned long addr, unsigned long instr, struct pt_regs *reg | ||||
|  * PU = 10             A                    B | ||||
|  */ | ||||
| static int | ||||
| do_alignment_ldmstm(unsigned long addr, unsigned long instr, struct pt_regs *regs) | ||||
| do_alignment_ldmstm(unsigned long addr, u32 instr, struct pt_regs *regs) | ||||
| { | ||||
| 	unsigned int rd, rn, correction, nr_regs, regbits; | ||||
| 	unsigned long eaddr, newaddr; | ||||
| @@ -539,7 +538,7 @@ do_alignment_ldmstm(unsigned long addr, unsigned long instr, struct pt_regs *reg | ||||
| 	 * processor for us. | ||||
| 	 */ | ||||
| 	if (addr != eaddr) { | ||||
| 		pr_err("LDMSTM: PC = %08lx, instr = %08lx, " | ||||
| 		pr_err("LDMSTM: PC = %08lx, instr = %08x, " | ||||
| 			"addr = %08lx, eaddr = %08lx\n", | ||||
| 			 instruction_pointer(regs), instr, addr, eaddr); | ||||
| 		show_regs(regs); | ||||
| @@ -716,10 +715,10 @@ thumb2arm(u16 tinstr) | ||||
|  * 2. Register name Rt from ARMv7 is same as Rd from ARMv6 (Rd is Rt) | ||||
|  */ | ||||
| static void * | ||||
| do_alignment_t32_to_handler(unsigned long *pinstr, struct pt_regs *regs, | ||||
| do_alignment_t32_to_handler(u32 *pinstr, struct pt_regs *regs, | ||||
| 			    union offset_union *poffset) | ||||
| { | ||||
| 	unsigned long instr = *pinstr; | ||||
| 	u32 instr = *pinstr; | ||||
| 	u16 tinst1 = (instr >> 16) & 0xffff; | ||||
| 	u16 tinst2 = instr & 0xffff; | ||||
| 
 | ||||
| @@ -767,17 +766,48 @@ do_alignment_t32_to_handler(unsigned long *pinstr, struct pt_regs *regs, | ||||
| 	return NULL; | ||||
| } | ||||
| 
 | ||||
| static int alignment_get_arm(struct pt_regs *regs, u32 *ip, u32 *inst) | ||||
| { | ||||
| 	u32 instr = 0; | ||||
| 	int fault; | ||||
| 
 | ||||
| 	if (user_mode(regs)) | ||||
| 		fault = get_user(instr, ip); | ||||
| 	else | ||||
| 		fault = probe_kernel_address(ip, instr); | ||||
| 
 | ||||
| 	*inst = __mem_to_opcode_arm(instr); | ||||
| 
 | ||||
| 	return fault; | ||||
| } | ||||
| 
 | ||||
| static int alignment_get_thumb(struct pt_regs *regs, u16 *ip, u16 *inst) | ||||
| { | ||||
| 	u16 instr = 0; | ||||
| 	int fault; | ||||
| 
 | ||||
| 	if (user_mode(regs)) | ||||
| 		fault = get_user(instr, ip); | ||||
| 	else | ||||
| 		fault = probe_kernel_address(ip, instr); | ||||
| 
 | ||||
| 	*inst = __mem_to_opcode_thumb16(instr); | ||||
| 
 | ||||
| 	return fault; | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs) | ||||
| { | ||||
| 	union offset_union uninitialized_var(offset); | ||||
| 	unsigned long instr = 0, instrptr; | ||||
| 	int (*handler)(unsigned long addr, unsigned long instr, struct pt_regs *regs); | ||||
| 	unsigned long instrptr; | ||||
| 	int (*handler)(unsigned long addr, u32 instr, struct pt_regs *regs); | ||||
| 	unsigned int type; | ||||
| 	unsigned int fault; | ||||
| 	u32 instr = 0; | ||||
| 	u16 tinstr = 0; | ||||
| 	int isize = 4; | ||||
| 	int thumb2_32b = 0; | ||||
| 	int fault; | ||||
| 
 | ||||
| 	if (interrupts_enabled(regs)) | ||||
| 		local_irq_enable(); | ||||
| @@ -786,15 +816,14 @@ do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs) | ||||
| 
 | ||||
| 	if (thumb_mode(regs)) { | ||||
| 		u16 *ptr = (u16 *)(instrptr & ~1); | ||||
| 		fault = probe_kernel_address(ptr, tinstr); | ||||
| 		tinstr = __mem_to_opcode_thumb16(tinstr); | ||||
| 
 | ||||
| 		fault = alignment_get_thumb(regs, ptr, &tinstr); | ||||
| 		if (!fault) { | ||||
| 			if (cpu_architecture() >= CPU_ARCH_ARMv7 && | ||||
| 			    IS_T32(tinstr)) { | ||||
| 				/* Thumb-2 32-bit */ | ||||
| 				u16 tinst2 = 0; | ||||
| 				fault = probe_kernel_address(ptr + 1, tinst2); | ||||
| 				tinst2 = __mem_to_opcode_thumb16(tinst2); | ||||
| 				u16 tinst2; | ||||
| 				fault = alignment_get_thumb(regs, ptr + 1, &tinst2); | ||||
| 				instr = __opcode_thumb32_compose(tinstr, tinst2); | ||||
| 				thumb2_32b = 1; | ||||
| 			} else { | ||||
| @@ -803,8 +832,7 @@ do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs) | ||||
| 			} | ||||
| 		} | ||||
| 	} else { | ||||
| 		fault = probe_kernel_address((void *)instrptr, instr); | ||||
| 		instr = __mem_to_opcode_arm(instr); | ||||
| 		fault = alignment_get_arm(regs, (void *)instrptr, &instr); | ||||
| 	} | ||||
| 
 | ||||
| 	if (fault) { | ||||
| @@ -926,7 +954,7 @@ do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs) | ||||
| 	 * Oops, we didn't handle the instruction. | ||||
| 	 */ | ||||
| 	pr_err("Alignment trap: not handling instruction " | ||||
| 		"%0*lx at [<%08lx>]\n", | ||||
| 		"%0*x at [<%08lx>]\n", | ||||
| 		isize << 1, | ||||
| 		isize == 2 ? tinstr : instr, instrptr); | ||||
| 	ai_skipped += 1; | ||||
| @@ -936,7 +964,7 @@ do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs) | ||||
| 	ai_user += 1; | ||||
| 
 | ||||
| 	if (ai_usermode & UM_WARN) | ||||
| 		printk("Alignment trap: %s (%d) PC=0x%08lx Instr=0x%0*lx " | ||||
| 		printk("Alignment trap: %s (%d) PC=0x%08lx Instr=0x%0*x " | ||||
| 		       "Address=0x%08lx FSR 0x%03x\n", current->comm, | ||||
| 			task_pid_nr(current), instrptr, | ||||
| 			isize << 1, | ||||
|   | ||||
| @@ -132,13 +132,11 @@ __v7m_setup_cont: | ||||
| 	dsb | ||||
| 	mov	r6, lr			@ save LR | ||||
| 	ldr	sp, =init_thread_union + THREAD_START_SP | ||||
| 	stmia	sp, {r0-r3, r12} | ||||
| 	cpsie	i | ||||
| 	svc	#0 | ||||
| 1:	cpsid	i | ||||
| 	ldr	r0, =exc_ret | ||||
| 	orr	lr, lr, #EXC_RET_THREADMODE_PROCESSSTACK | ||||
| 	str	lr, [r0] | ||||
| 	/* Calculate exc_ret */ | ||||
| 	orr	r10, lr, #EXC_RET_THREADMODE_PROCESSSTACK | ||||
| 	ldmia	sp, {r0-r3, r12} | ||||
| 	str	r5, [r12, #11 * 4]	@ restore the original SVC vector entry | ||||
| 	mov	lr, r6			@ restore LR | ||||
|   | ||||
| @@ -616,6 +616,23 @@ config CAVIUM_ERRATUM_30115 | ||||
|  | ||||
| 	  If unsure, say Y. | ||||
|  | ||||
| config CAVIUM_TX2_ERRATUM_219 | ||||
| 	bool "Cavium ThunderX2 erratum 219: PRFM between TTBR change and ISB fails" | ||||
| 	default y | ||||
| 	help | ||||
| 	  On Cavium ThunderX2, a load, store or prefetch instruction between a | ||||
| 	  TTBR update and the corresponding context synchronizing operation can | ||||
| 	  cause a spurious Data Abort to be delivered to any hardware thread in | ||||
| 	  the CPU core. | ||||
|  | ||||
| 	  Work around the issue by avoiding the problematic code sequence and | ||||
| 	  trapping KVM guest TTBRx_EL1 writes to EL2 when SMT is enabled. The | ||||
| 	  trap handler performs the corresponding register access, skips the | ||||
| 	  instruction and ensures context synchronization by virtue of the | ||||
| 	  exception return. | ||||
|  | ||||
| 	  If unsure, say Y. | ||||
|  | ||||
| config QCOM_FALKOR_ERRATUM_1003 | ||||
| 	bool "Falkor E1003: Incorrect translation due to ASID change" | ||||
| 	default y | ||||
|   | ||||
| @@ -63,3 +63,12 @@ | ||||
| 		reg = <1>; | ||||
| 	}; | ||||
| }; | ||||
|  | ||||
| ®_dc1sw { | ||||
| 	/* | ||||
| 	 * Ethernet PHY needs 30ms to properly power up and some more | ||||
| 	 * to initialize. 100ms should be plenty of time to finish | ||||
| 	 * whole process. | ||||
| 	 */ | ||||
| 	regulator-enable-ramp-delay = <100000>; | ||||
| }; | ||||
|   | ||||
| @@ -159,6 +159,12 @@ | ||||
| }; | ||||
|  | ||||
| ®_dc1sw { | ||||
| 	/* | ||||
| 	 * Ethernet PHY needs 30ms to properly power up and some more | ||||
| 	 * to initialize. 100ms should be plenty of time to finish | ||||
| 	 * whole process. | ||||
| 	 */ | ||||
| 	regulator-enable-ramp-delay = <100000>; | ||||
| 	regulator-name = "vcc-phy"; | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -142,15 +142,6 @@ | ||||
| 		clock-output-names = "ext-osc32k"; | ||||
| 	}; | ||||
|  | ||||
| 	pmu { | ||||
| 		compatible = "arm,cortex-a53-pmu"; | ||||
| 		interrupts = <GIC_SPI 152 IRQ_TYPE_LEVEL_HIGH>, | ||||
| 			     <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>, | ||||
| 			     <GIC_SPI 154 IRQ_TYPE_LEVEL_HIGH>, | ||||
| 			     <GIC_SPI 155 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 		interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>; | ||||
| 	}; | ||||
|  | ||||
| 	psci { | ||||
| 		compatible = "arm,psci-0.2"; | ||||
| 		method = "smc"; | ||||
|   | ||||
| @@ -42,13 +42,14 @@ | ||||
|  | ||||
| 		pinmux: pinmux@14029c { | ||||
| 			compatible = "pinctrl-single"; | ||||
| 			reg = <0x0014029c 0x250>; | ||||
| 			reg = <0x0014029c 0x26c>; | ||||
| 			#address-cells = <1>; | ||||
| 			#size-cells = <1>; | ||||
| 			pinctrl-single,register-width = <32>; | ||||
| 			pinctrl-single,function-mask = <0xf>; | ||||
| 			pinctrl-single,gpio-range = < | ||||
| 				&range 0 154 MODE_GPIO | ||||
| 				&range 0  91 MODE_GPIO | ||||
| 				&range 95 60 MODE_GPIO | ||||
| 				>; | ||||
| 			range: gpio-range { | ||||
| 				#pinctrl-single,gpio-range-cells = <3>; | ||||
|   | ||||
| @@ -464,8 +464,7 @@ | ||||
| 					<&pinmux 108 16 27>, | ||||
| 					<&pinmux 135 77 6>, | ||||
| 					<&pinmux 141 67 4>, | ||||
| 					<&pinmux 145 149 6>, | ||||
| 					<&pinmux 151 91 4>; | ||||
| 					<&pinmux 145 149 6>; | ||||
| 		}; | ||||
|  | ||||
| 		i2c1: i2c@e0000 { | ||||
|   | ||||
| @@ -33,7 +33,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster0_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@1 { | ||||
| @@ -49,7 +49,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster0_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@100 { | ||||
| @@ -65,7 +65,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster1_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@101 { | ||||
| @@ -81,7 +81,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster1_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@200 { | ||||
| @@ -97,7 +97,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster2_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@201 { | ||||
| @@ -113,7 +113,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster2_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@300 { | ||||
| @@ -129,7 +129,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster3_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@301 { | ||||
| @@ -145,7 +145,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster3_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@400 { | ||||
| @@ -161,7 +161,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster4_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@401 { | ||||
| @@ -177,7 +177,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster4_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@500 { | ||||
| @@ -193,7 +193,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster5_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@501 { | ||||
| @@ -209,7 +209,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster5_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@600 { | ||||
| @@ -225,7 +225,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster6_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@601 { | ||||
| @@ -241,7 +241,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster6_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@700 { | ||||
| @@ -257,7 +257,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster7_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu@701 { | ||||
| @@ -273,7 +273,7 @@ | ||||
| 			i-cache-line-size = <64>; | ||||
| 			i-cache-sets = <192>; | ||||
| 			next-level-cache = <&cluster7_l2>; | ||||
| 			cpu-idle-states = <&cpu_pw20>; | ||||
| 			cpu-idle-states = <&cpu_pw15>; | ||||
| 		}; | ||||
|  | ||||
| 		cluster0_l2: l2-cache0 { | ||||
| @@ -340,9 +340,9 @@ | ||||
| 			cache-level = <2>; | ||||
| 		}; | ||||
|  | ||||
| 		cpu_pw20: cpu-pw20 { | ||||
| 		cpu_pw15: cpu-pw15 { | ||||
| 			compatible = "arm,idle-state"; | ||||
| 			idle-state-name = "PW20"; | ||||
| 			idle-state-name = "PW15"; | ||||
| 			arm,psci-suspend-param = <0x0>; | ||||
| 			entry-latency-us = <2000>; | ||||
| 			exit-latency-us = <2000>; | ||||
|   | ||||
| @@ -694,7 +694,7 @@ | ||||
| 				compatible = "fsl,imx8mm-usdhc", "fsl,imx7d-usdhc"; | ||||
| 				reg = <0x30b40000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clk IMX8MM_CLK_DUMMY>, | ||||
| 				clocks = <&clk IMX8MM_CLK_IPG_ROOT>, | ||||
| 					 <&clk IMX8MM_CLK_NAND_USDHC_BUS>, | ||||
| 					 <&clk IMX8MM_CLK_USDHC1_ROOT>; | ||||
| 				clock-names = "ipg", "ahb", "per"; | ||||
| @@ -710,7 +710,7 @@ | ||||
| 				compatible = "fsl,imx8mm-usdhc", "fsl,imx7d-usdhc"; | ||||
| 				reg = <0x30b50000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clk IMX8MM_CLK_DUMMY>, | ||||
| 				clocks = <&clk IMX8MM_CLK_IPG_ROOT>, | ||||
| 					 <&clk IMX8MM_CLK_NAND_USDHC_BUS>, | ||||
| 					 <&clk IMX8MM_CLK_USDHC2_ROOT>; | ||||
| 				clock-names = "ipg", "ahb", "per"; | ||||
| @@ -724,7 +724,7 @@ | ||||
| 				compatible = "fsl,imx8mm-usdhc", "fsl,imx7d-usdhc"; | ||||
| 				reg = <0x30b60000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clk IMX8MM_CLK_DUMMY>, | ||||
| 				clocks = <&clk IMX8MM_CLK_IPG_ROOT>, | ||||
| 					 <&clk IMX8MM_CLK_NAND_USDHC_BUS>, | ||||
| 					 <&clk IMX8MM_CLK_USDHC3_ROOT>; | ||||
| 				clock-names = "ipg", "ahb", "per"; | ||||
|   | ||||
| @@ -569,7 +569,7 @@ | ||||
| 				compatible = "fsl,imx8mn-usdhc", "fsl,imx7d-usdhc"; | ||||
| 				reg = <0x30b40000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clk IMX8MN_CLK_DUMMY>, | ||||
| 				clocks = <&clk IMX8MN_CLK_IPG_ROOT>, | ||||
| 					 <&clk IMX8MN_CLK_NAND_USDHC_BUS>, | ||||
| 					 <&clk IMX8MN_CLK_USDHC1_ROOT>; | ||||
| 				clock-names = "ipg", "ahb", "per"; | ||||
| @@ -585,7 +585,7 @@ | ||||
| 				compatible = "fsl,imx8mn-usdhc", "fsl,imx7d-usdhc"; | ||||
| 				reg = <0x30b50000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clk IMX8MN_CLK_DUMMY>, | ||||
| 				clocks = <&clk IMX8MN_CLK_IPG_ROOT>, | ||||
| 					 <&clk IMX8MN_CLK_NAND_USDHC_BUS>, | ||||
| 					 <&clk IMX8MN_CLK_USDHC2_ROOT>; | ||||
| 				clock-names = "ipg", "ahb", "per"; | ||||
| @@ -599,7 +599,7 @@ | ||||
| 				compatible = "fsl,imx8mn-usdhc", "fsl,imx7d-usdhc"; | ||||
| 				reg = <0x30b60000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clk IMX8MN_CLK_DUMMY>, | ||||
| 				clocks = <&clk IMX8MN_CLK_IPG_ROOT>, | ||||
| 					 <&clk IMX8MN_CLK_NAND_USDHC_BUS>, | ||||
| 					 <&clk IMX8MN_CLK_USDHC3_ROOT>; | ||||
| 				clock-names = "ipg", "ahb", "per"; | ||||
|   | ||||
| @@ -89,8 +89,8 @@ | ||||
| 		regulator-min-microvolt = <900000>; | ||||
| 		regulator-max-microvolt = <1000000>; | ||||
| 		gpios = <&gpio3 19 GPIO_ACTIVE_HIGH>; | ||||
| 		states = <1000000 0x0 | ||||
| 		           900000 0x1>; | ||||
| 		states = <1000000 0x1 | ||||
| 		           900000 0x0>; | ||||
| 		regulator-always-on; | ||||
| 	}; | ||||
| }; | ||||
|   | ||||
| @@ -850,7 +850,7 @@ | ||||
| 				             "fsl,imx7d-usdhc"; | ||||
| 				reg = <0x30b40000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clk IMX8MQ_CLK_DUMMY>, | ||||
| 				clocks = <&clk IMX8MQ_CLK_IPG_ROOT>, | ||||
| 				         <&clk IMX8MQ_CLK_NAND_USDHC_BUS>, | ||||
| 				         <&clk IMX8MQ_CLK_USDHC1_ROOT>; | ||||
| 				clock-names = "ipg", "ahb", "per"; | ||||
| @@ -867,7 +867,7 @@ | ||||
| 				             "fsl,imx7d-usdhc"; | ||||
| 				reg = <0x30b50000 0x10000>; | ||||
| 				interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>; | ||||
| 				clocks = <&clk IMX8MQ_CLK_DUMMY>, | ||||
| 				clocks = <&clk IMX8MQ_CLK_IPG_ROOT>, | ||||
| 				         <&clk IMX8MQ_CLK_NAND_USDHC_BUS>, | ||||
| 				         <&clk IMX8MQ_CLK_USDHC2_ROOT>; | ||||
| 				clock-names = "ipg", "ahb", "per"; | ||||
|   | ||||
| @@ -60,11 +60,6 @@ | ||||
| 		gpio = <&gpiosb 0 GPIO_ACTIVE_HIGH>; | ||||
| 	}; | ||||
|  | ||||
| 	usb3_phy: usb3-phy { | ||||
| 		compatible = "usb-nop-xceiv"; | ||||
| 		vcc-supply = <&exp_usb3_vbus>; | ||||
| 	}; | ||||
|  | ||||
| 	vsdc_reg: vsdc-reg { | ||||
| 		compatible = "regulator-gpio"; | ||||
| 		regulator-name = "vsdc"; | ||||
| @@ -255,10 +250,16 @@ | ||||
| 	status = "okay"; | ||||
| }; | ||||
|  | ||||
| &comphy2 { | ||||
| 	connector { | ||||
| 		compatible = "usb-a-connector"; | ||||
| 		phy-supply = <&exp_usb3_vbus>; | ||||
| 	}; | ||||
| }; | ||||
|  | ||||
| &usb3 { | ||||
| 	status = "okay"; | ||||
| 	phys = <&comphy2 0>; | ||||
| 	usb-phy = <&usb3_phy>; | ||||
| }; | ||||
|  | ||||
| &mdio { | ||||
|   | ||||
| @@ -44,7 +44,7 @@ | ||||
| 		power-supply = <&pp3300_disp>; | ||||
|  | ||||
| 		panel-timing { | ||||
| 			clock-frequency = <266604720>; | ||||
| 			clock-frequency = <266666667>; | ||||
| 			hactive = <2400>; | ||||
| 			hfront-porch = <48>; | ||||
| 			hback-porch = <84>; | ||||
|   | ||||
| @@ -644,7 +644,7 @@ | ||||
| 	status = "okay"; | ||||
|  | ||||
| 	u2phy0_host: host-port { | ||||
| 		phy-supply = <&vcc5v0_host>; | ||||
| 		phy-supply = <&vcc5v0_typec>; | ||||
| 		status = "okay"; | ||||
| 	}; | ||||
|  | ||||
| @@ -712,7 +712,7 @@ | ||||
|  | ||||
| &usbdrd_dwc3_0 { | ||||
| 	status = "okay"; | ||||
| 	dr_mode = "otg"; | ||||
| 	dr_mode = "host"; | ||||
| }; | ||||
|  | ||||
| &usbdrd3_1 { | ||||
|   | ||||
| @@ -173,7 +173,7 @@ | ||||
| 		regulator-always-on; | ||||
| 		regulator-boot-on; | ||||
| 		regulator-min-microvolt = <800000>; | ||||
| 		regulator-max-microvolt = <1400000>; | ||||
| 		regulator-max-microvolt = <1700000>; | ||||
| 		vin-supply = <&vcc5v0_sys>; | ||||
| 	}; | ||||
| }; | ||||
| @@ -247,8 +247,8 @@ | ||||
| 	rk808: pmic@1b { | ||||
| 		compatible = "rockchip,rk808"; | ||||
| 		reg = <0x1b>; | ||||
| 		interrupt-parent = <&gpio1>; | ||||
| 		interrupts = <21 IRQ_TYPE_LEVEL_LOW>; | ||||
| 		interrupt-parent = <&gpio3>; | ||||
| 		interrupts = <10 IRQ_TYPE_LEVEL_LOW>; | ||||
| 		#clock-cells = <1>; | ||||
| 		clock-output-names = "xin32k", "rk808-clkout2"; | ||||
| 		pinctrl-names = "default"; | ||||
| @@ -574,7 +574,7 @@ | ||||
|  | ||||
| 	pmic { | ||||
| 		pmic_int_l: pmic-int-l { | ||||
| 			rockchip,pins = <1 RK_PC5 RK_FUNC_GPIO &pcfg_pull_up>; | ||||
| 			rockchip,pins = <3 RK_PB2 RK_FUNC_GPIO &pcfg_pull_up>; | ||||
| 		}; | ||||
|  | ||||
| 		vsel1_gpio: vsel1-gpio { | ||||
| @@ -624,7 +624,6 @@ | ||||
|  | ||||
| &sdmmc { | ||||
| 	bus-width = <4>; | ||||
| 	cap-mmc-highspeed; | ||||
| 	cap-sd-highspeed; | ||||
| 	cd-gpios = <&gpio0 7 GPIO_ACTIVE_LOW>; | ||||
| 	disable-wp; | ||||
| @@ -636,8 +635,7 @@ | ||||
|  | ||||
| &sdhci { | ||||
| 	bus-width = <8>; | ||||
| 	mmc-hs400-1_8v; | ||||
| 	mmc-hs400-enhanced-strobe; | ||||
| 	mmc-hs200-1_8v; | ||||
| 	non-removable; | ||||
| 	status = "okay"; | ||||
| }; | ||||
|   | ||||
| @@ -78,10 +78,9 @@ alternative_else_nop_endif | ||||
| /*
 | ||||
|  * Remove the address tag from a virtual address, if present. | ||||
|  */ | ||||
| 	.macro	clear_address_tag, dst, addr | ||||
| 	tst	\addr, #(1 << 55) | ||||
| 	bic	\dst, \addr, #(0xff << 56) | ||||
| 	csel	\dst, \dst, \addr, eq | ||||
| 	.macro	untagged_addr, dst, addr | ||||
| 	sbfx	\dst, \addr, #0, #56 | ||||
| 	and	\dst, \dst, \addr | ||||
| 	.endm | ||||
| 
 | ||||
| #endif | ||||
|   | ||||
| @@ -52,7 +52,9 @@ | ||||
| #define ARM64_HAS_IRQ_PRIO_MASKING		42 | ||||
| #define ARM64_HAS_DCPODP			43 | ||||
| #define ARM64_WORKAROUND_1463225		44 | ||||
| #define ARM64_WORKAROUND_CAVIUM_TX2_219_TVM	45 | ||||
| #define ARM64_WORKAROUND_CAVIUM_TX2_219_PRFM	46 | ||||
| 
 | ||||
| #define ARM64_NCAPS				45 | ||||
| #define ARM64_NCAPS				47 | ||||
| 
 | ||||
| #endif /* __ASM_CPUCAPS_H */ | ||||
|   | ||||
| @@ -215,12 +215,18 @@ static inline unsigned long kaslr_offset(void) | ||||
|  * up with a tagged userland pointer. Clear the tag to get a sane pointer to | ||||
|  * pass on to access_ok(), for instance. | ||||
|  */ | ||||
| #define untagged_addr(addr)	\ | ||||
| #define __untagged_addr(addr)	\ | ||||
| 	((__force __typeof__(addr))sign_extend64((__force u64)(addr), 55)) | ||||
| 
 | ||||
| #define untagged_addr(addr)	({					\ | ||||
| 	u64 __addr = (__force u64)addr;					\ | ||||
| 	__addr &= __untagged_addr(__addr);				\ | ||||
| 	(__force __typeof__(addr))__addr;				\ | ||||
| }) | ||||
| 
 | ||||
| #ifdef CONFIG_KASAN_SW_TAGS | ||||
| #define __tag_shifted(tag)	((u64)(tag) << 56) | ||||
| #define __tag_reset(addr)	untagged_addr(addr) | ||||
| #define __tag_reset(addr)	__untagged_addr(addr) | ||||
| #define __tag_get(addr)		(__u8)((u64)(addr) >> 56) | ||||
| #else | ||||
| #define __tag_shifted(tag)	0UL | ||||
|   | ||||
| @@ -876,9 +876,6 @@ static inline void update_mmu_cache(struct vm_area_struct *vma, | ||||
| 
 | ||||
| #define update_mmu_cache_pmd(vma, address, pmd) do { } while (0) | ||||
| 
 | ||||
| #define kc_vaddr_to_offset(v)	((v) & ~PAGE_END) | ||||
| #define kc_offset_to_vaddr(o)	((o) | PAGE_END) | ||||
| 
 | ||||
| #ifdef CONFIG_ARM64_PA_BITS_52 | ||||
| #define phys_to_ttbr(addr)	(((addr) | ((addr) >> 46)) & TTBR_BADDR_MASK_52) | ||||
| #else | ||||
|   | ||||
| @@ -212,7 +212,7 @@ | ||||
| #define SYS_FAR_EL1			sys_reg(3, 0, 6, 0, 0) | ||||
| #define SYS_PAR_EL1			sys_reg(3, 0, 7, 4, 0) | ||||
| 
 | ||||
| #define SYS_PAR_EL1_F			BIT(1) | ||||
| #define SYS_PAR_EL1_F			BIT(0) | ||||
| #define SYS_PAR_EL1_FST			GENMASK(6, 1) | ||||
| 
 | ||||
| /*** Statistical Profiling Extension ***/ | ||||
|   | ||||
| @@ -12,6 +12,7 @@ | ||||
| #include <asm/cpu.h> | ||||
| #include <asm/cputype.h> | ||||
| #include <asm/cpufeature.h> | ||||
| #include <asm/smp_plat.h> | ||||
| 
 | ||||
| static bool __maybe_unused | ||||
| is_affected_midr_range(const struct arm64_cpu_capabilities *entry, int scope) | ||||
| @@ -623,6 +624,30 @@ check_branch_predictor(const struct arm64_cpu_capabilities *entry, int scope) | ||||
| 	return (need_wa > 0); | ||||
| } | ||||
| 
 | ||||
| static const __maybe_unused struct midr_range tx2_family_cpus[] = { | ||||
| 	MIDR_ALL_VERSIONS(MIDR_BRCM_VULCAN), | ||||
| 	MIDR_ALL_VERSIONS(MIDR_CAVIUM_THUNDERX2), | ||||
| 	{}, | ||||
| }; | ||||
| 
 | ||||
| static bool __maybe_unused | ||||
| needs_tx2_tvm_workaround(const struct arm64_cpu_capabilities *entry, | ||||
| 			 int scope) | ||||
| { | ||||
| 	int i; | ||||
| 
 | ||||
| 	if (!is_affected_midr_range_list(entry, scope) || | ||||
| 	    !is_hyp_mode_available()) | ||||
| 		return false; | ||||
| 
 | ||||
| 	for_each_possible_cpu(i) { | ||||
| 		if (MPIDR_AFFINITY_LEVEL(cpu_logical_map(i), 0) != 0) | ||||
| 			return true; | ||||
| 	} | ||||
| 
 | ||||
| 	return false; | ||||
| } | ||||
| 
 | ||||
| #ifdef CONFIG_HARDEN_EL2_VECTORS | ||||
| 
 | ||||
| static const struct midr_range arm64_harden_el2_vectors[] = { | ||||
| @@ -851,6 +876,19 @@ const struct arm64_cpu_capabilities arm64_errata[] = { | ||||
| 		.type = ARM64_CPUCAP_LOCAL_CPU_ERRATUM, | ||||
| 		.matches = has_cortex_a76_erratum_1463225, | ||||
| 	}, | ||||
| #endif | ||||
| #ifdef CONFIG_CAVIUM_TX2_ERRATUM_219 | ||||
| 	{ | ||||
| 		.desc = "Cavium ThunderX2 erratum 219 (KVM guest sysreg trapping)", | ||||
| 		.capability = ARM64_WORKAROUND_CAVIUM_TX2_219_TVM, | ||||
| 		ERRATA_MIDR_RANGE_LIST(tx2_family_cpus), | ||||
| 		.matches = needs_tx2_tvm_workaround, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.desc = "Cavium ThunderX2 erratum 219 (PRFM removal)", | ||||
| 		.capability = ARM64_WORKAROUND_CAVIUM_TX2_219_PRFM, | ||||
| 		ERRATA_MIDR_RANGE_LIST(tx2_family_cpus), | ||||
| 	}, | ||||
| #endif | ||||
| 	{ | ||||
| 	} | ||||
|   | ||||
| @@ -176,11 +176,16 @@ static const struct arm64_ftr_bits ftr_id_aa64pfr1[] = { | ||||
| }; | ||||
| 
 | ||||
| static const struct arm64_ftr_bits ftr_id_aa64zfr0[] = { | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_SM4_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_SHA3_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_BITPERM_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_AES_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_SVEVER_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), | ||||
| 		       FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_SM4_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), | ||||
| 		       FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_SHA3_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), | ||||
| 		       FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_BITPERM_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), | ||||
| 		       FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_AES_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), | ||||
| 		       FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_SVEVER_SHIFT, 4, 0), | ||||
| 	ARM64_FTR_END, | ||||
| }; | ||||
| 
 | ||||
|   | ||||
| @@ -604,7 +604,7 @@ el1_da: | ||||
| 	 */ | ||||
| 	mrs	x3, far_el1 | ||||
| 	inherit_daif	pstate=x23, tmp=x2 | ||||
| 	clear_address_tag x0, x3 | ||||
| 	untagged_addr	x0, x3 | ||||
| 	mov	x2, sp				// struct pt_regs | ||||
| 	bl	do_mem_abort | ||||
|  | ||||
| @@ -680,7 +680,7 @@ alternative_if ARM64_HAS_IRQ_PRIO_MASKING | ||||
| 	orr	x24, x24, x0 | ||||
| alternative_else_nop_endif | ||||
| 	cbnz	x24, 1f				// preempt count != 0 || NMI return path | ||||
| 	bl	preempt_schedule_irq		// irq en/disable is done inside | ||||
| 	bl	arm64_preempt_schedule_irq	// irq en/disable is done inside | ||||
| 1: | ||||
| #endif | ||||
|  | ||||
| @@ -808,7 +808,7 @@ el0_da: | ||||
| 	mrs	x26, far_el1 | ||||
| 	ct_user_exit_irqoff | ||||
| 	enable_daif | ||||
| 	clear_address_tag x0, x26 | ||||
| 	untagged_addr	x0, x26 | ||||
| 	mov	x1, x25 | ||||
| 	mov	x2, sp | ||||
| 	bl	do_mem_abort | ||||
| @@ -1071,7 +1071,9 @@ alternative_insn isb, nop, ARM64_WORKAROUND_QCOM_FALKOR_E1003 | ||||
| #else | ||||
| 	ldr	x30, =vectors | ||||
| #endif | ||||
| alternative_if_not ARM64_WORKAROUND_CAVIUM_TX2_219_PRFM | ||||
| 	prfm	plil1strm, [x30, #(1b - tramp_vectors)] | ||||
| alternative_else_nop_endif | ||||
| 	msr	vbar_el1, x30 | ||||
| 	add	x30, x30, #(1b - tramp_vectors) | ||||
| 	isb | ||||
|   | ||||
| @@ -201,6 +201,7 @@ static int create_safe_exec_page(void *src_start, size_t length, | ||||
| 				 gfp_t mask) | ||||
| { | ||||
| 	int rc = 0; | ||||
| 	pgd_t *trans_pgd; | ||||
| 	pgd_t *pgdp; | ||||
| 	pud_t *pudp; | ||||
| 	pmd_t *pmdp; | ||||
| @@ -215,7 +216,13 @@ static int create_safe_exec_page(void *src_start, size_t length, | ||||
| 	memcpy((void *)dst, src_start, length); | ||||
| 	__flush_icache_range(dst, dst + length); | ||||
| 
 | ||||
| 	pgdp = pgd_offset_raw(allocator(mask), dst_addr); | ||||
| 	trans_pgd = allocator(mask); | ||||
| 	if (!trans_pgd) { | ||||
| 		rc = -ENOMEM; | ||||
| 		goto out; | ||||
| 	} | ||||
| 
 | ||||
| 	pgdp = pgd_offset_raw(trans_pgd, dst_addr); | ||||
| 	if (pgd_none(READ_ONCE(*pgdp))) { | ||||
| 		pudp = allocator(mask); | ||||
| 		if (!pudp) { | ||||
|   | ||||
| @@ -17,6 +17,7 @@ | ||||
| #include <linux/sched/task.h> | ||||
| #include <linux/sched/task_stack.h> | ||||
| #include <linux/kernel.h> | ||||
| #include <linux/lockdep.h> | ||||
| #include <linux/mm.h> | ||||
| #include <linux/stddef.h> | ||||
| #include <linux/sysctl.h> | ||||
| @@ -44,6 +45,7 @@ | ||||
| #include <asm/alternative.h> | ||||
| #include <asm/arch_gicv3.h> | ||||
| #include <asm/compat.h> | ||||
| #include <asm/cpufeature.h> | ||||
| #include <asm/cacheflush.h> | ||||
| #include <asm/exec.h> | ||||
| #include <asm/fpsimd.h> | ||||
| @@ -631,3 +633,19 @@ static int __init tagged_addr_init(void) | ||||
| 
 | ||||
| core_initcall(tagged_addr_init); | ||||
| #endif	/* CONFIG_ARM64_TAGGED_ADDR_ABI */ | ||||
| 
 | ||||
| asmlinkage void __sched arm64_preempt_schedule_irq(void) | ||||
| { | ||||
| 	lockdep_assert_irqs_disabled(); | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * Preempting a task from an IRQ means we leave copies of PSTATE | ||||
| 	 * on the stack. cpufeature's enable calls may modify PSTATE, but | ||||
| 	 * resuming one of these preempted tasks would undo those changes. | ||||
| 	 * | ||||
| 	 * Only allow a task to be preempted once cpufeatures have been | ||||
| 	 * enabled. | ||||
| 	 */ | ||||
| 	if (static_branch_likely(&arm64_const_caps_ready)) | ||||
| 		preempt_schedule_irq(); | ||||
| } | ||||
|   | ||||
| @@ -124,6 +124,9 @@ static void __hyp_text __activate_traps(struct kvm_vcpu *vcpu) | ||||
| { | ||||
| 	u64 hcr = vcpu->arch.hcr_el2; | ||||
| 
 | ||||
| 	if (cpus_have_const_cap(ARM64_WORKAROUND_CAVIUM_TX2_219_TVM)) | ||||
| 		hcr |= HCR_TVM; | ||||
| 
 | ||||
| 	write_sysreg(hcr, hcr_el2); | ||||
| 
 | ||||
| 	if (cpus_have_const_cap(ARM64_HAS_RAS_EXTN) && (hcr & HCR_VSE)) | ||||
| @@ -174,8 +177,10 @@ static void __hyp_text __deactivate_traps(struct kvm_vcpu *vcpu) | ||||
| 	 * the crucial bit is "On taking a vSError interrupt, | ||||
| 	 * HCR_EL2.VSE is cleared to 0." | ||||
| 	 */ | ||||
| 	if (vcpu->arch.hcr_el2 & HCR_VSE) | ||||
| 		vcpu->arch.hcr_el2 = read_sysreg(hcr_el2); | ||||
| 	if (vcpu->arch.hcr_el2 & HCR_VSE) { | ||||
| 		vcpu->arch.hcr_el2 &= ~HCR_VSE; | ||||
| 		vcpu->arch.hcr_el2 |= read_sysreg(hcr_el2) & HCR_VSE; | ||||
| 	} | ||||
| 
 | ||||
| 	if (has_vhe()) | ||||
| 		deactivate_traps_vhe(); | ||||
| @@ -380,6 +385,61 @@ static bool __hyp_text __hyp_handle_fpsimd(struct kvm_vcpu *vcpu) | ||||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| static bool __hyp_text handle_tx2_tvm(struct kvm_vcpu *vcpu) | ||||
| { | ||||
| 	u32 sysreg = esr_sys64_to_sysreg(kvm_vcpu_get_hsr(vcpu)); | ||||
| 	int rt = kvm_vcpu_sys_get_rt(vcpu); | ||||
| 	u64 val = vcpu_get_reg(vcpu, rt); | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * The normal sysreg handling code expects to see the traps, | ||||
| 	 * let's not do anything here. | ||||
| 	 */ | ||||
| 	if (vcpu->arch.hcr_el2 & HCR_TVM) | ||||
| 		return false; | ||||
| 
 | ||||
| 	switch (sysreg) { | ||||
| 	case SYS_SCTLR_EL1: | ||||
| 		write_sysreg_el1(val, SYS_SCTLR); | ||||
| 		break; | ||||
| 	case SYS_TTBR0_EL1: | ||||
| 		write_sysreg_el1(val, SYS_TTBR0); | ||||
| 		break; | ||||
| 	case SYS_TTBR1_EL1: | ||||
| 		write_sysreg_el1(val, SYS_TTBR1); | ||||
| 		break; | ||||
| 	case SYS_TCR_EL1: | ||||
| 		write_sysreg_el1(val, SYS_TCR); | ||||
| 		break; | ||||
| 	case SYS_ESR_EL1: | ||||
| 		write_sysreg_el1(val, SYS_ESR); | ||||
| 		break; | ||||
| 	case SYS_FAR_EL1: | ||||
| 		write_sysreg_el1(val, SYS_FAR); | ||||
| 		break; | ||||
| 	case SYS_AFSR0_EL1: | ||||
| 		write_sysreg_el1(val, SYS_AFSR0); | ||||
| 		break; | ||||
| 	case SYS_AFSR1_EL1: | ||||
| 		write_sysreg_el1(val, SYS_AFSR1); | ||||
| 		break; | ||||
| 	case SYS_MAIR_EL1: | ||||
| 		write_sysreg_el1(val, SYS_MAIR); | ||||
| 		break; | ||||
| 	case SYS_AMAIR_EL1: | ||||
| 		write_sysreg_el1(val, SYS_AMAIR); | ||||
| 		break; | ||||
| 	case SYS_CONTEXTIDR_EL1: | ||||
| 		write_sysreg_el1(val, SYS_CONTEXTIDR); | ||||
| 		break; | ||||
| 	default: | ||||
| 		return false; | ||||
| 	} | ||||
| 
 | ||||
| 	__kvm_skip_instr(vcpu); | ||||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Return true when we were able to fixup the guest exit and should return to | ||||
|  * the guest, false when we should restore the host state and return to the | ||||
| @@ -399,6 +459,11 @@ static bool __hyp_text fixup_guest_exit(struct kvm_vcpu *vcpu, u64 *exit_code) | ||||
| 	if (*exit_code != ARM_EXCEPTION_TRAP) | ||||
| 		goto exit; | ||||
| 
 | ||||
| 	if (cpus_have_const_cap(ARM64_WORKAROUND_CAVIUM_TX2_219_TVM) && | ||||
| 	    kvm_vcpu_trap_get_class(vcpu) == ESR_ELx_EC_SYS64 && | ||||
| 	    handle_tx2_tvm(vcpu)) | ||||
| 		return true; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * We trap the first access to the FP/SIMD to save the host context | ||||
| 	 * and restore the guest context lazily. | ||||
|   | ||||
| @@ -632,6 +632,8 @@ static void reset_pmcr(struct kvm_vcpu *vcpu, const struct sys_reg_desc *r) | ||||
| 	 */ | ||||
| 	val = ((pmcr & ~ARMV8_PMU_PMCR_MASK) | ||||
| 	       | (ARMV8_PMU_PMCR_MASK & 0xdecafbad)) & (~ARMV8_PMU_PMCR_E); | ||||
| 	if (!system_supports_32bit_el0()) | ||||
| 		val |= ARMV8_PMU_PMCR_LC; | ||||
| 	__vcpu_sys_reg(vcpu, r->reg) = val; | ||||
| } | ||||
| 
 | ||||
| @@ -682,6 +684,8 @@ static bool access_pmcr(struct kvm_vcpu *vcpu, struct sys_reg_params *p, | ||||
| 		val = __vcpu_sys_reg(vcpu, PMCR_EL0); | ||||
| 		val &= ~ARMV8_PMU_PMCR_MASK; | ||||
| 		val |= p->regval & ARMV8_PMU_PMCR_MASK; | ||||
| 		if (!system_supports_32bit_el0()) | ||||
| 			val |= ARMV8_PMU_PMCR_LC; | ||||
| 		__vcpu_sys_reg(vcpu, PMCR_EL0) = val; | ||||
| 		kvm_pmu_handle_pmcr(vcpu, val); | ||||
| 		kvm_vcpu_pmu_restore_guest(vcpu); | ||||
|   | ||||
| @@ -268,8 +268,12 @@ static bool __kprobes is_spurious_el1_translation_fault(unsigned long addr, | ||||
| 	par = read_sysreg(par_el1); | ||||
| 	local_irq_restore(flags); | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * If we now have a valid translation, treat the translation fault as | ||||
| 	 * spurious. | ||||
| 	 */ | ||||
| 	if (!(par & SYS_PAR_EL1_F)) | ||||
| 		return false; | ||||
| 		return true; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * If we got a different type of fault from the AT instruction, | ||||
|   | ||||
| @@ -84,7 +84,7 @@ void __init prom_init(void) | ||||
| 		 * Here we will start up CPU1 in the background and ask it to | ||||
| 		 * reconfigure itself then go back to sleep. | ||||
| 		 */ | ||||
| 		memcpy((void *)0xa0000200, &bmips_smp_movevec, 0x20); | ||||
| 		memcpy((void *)0xa0000200, bmips_smp_movevec, 0x20); | ||||
| 		__sync(); | ||||
| 		set_c0_cause(C_SW0); | ||||
| 		cpumask_set_cpu(1, &bmips_booted_mask); | ||||
|   | ||||
| @@ -75,11 +75,11 @@ static inline int register_bmips_smp_ops(void) | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| extern char bmips_reset_nmi_vec; | ||||
| extern char bmips_reset_nmi_vec_end; | ||||
| extern char bmips_smp_movevec; | ||||
| extern char bmips_smp_int_vec; | ||||
| extern char bmips_smp_int_vec_end; | ||||
| extern char bmips_reset_nmi_vec[]; | ||||
| extern char bmips_reset_nmi_vec_end[]; | ||||
| extern char bmips_smp_movevec[]; | ||||
| extern char bmips_smp_int_vec[]; | ||||
| extern char bmips_smp_int_vec_end[]; | ||||
| 
 | ||||
| extern int bmips_smp_enabled; | ||||
| extern int bmips_cpu_offset; | ||||
|   | ||||
| @@ -24,6 +24,8 @@ | ||||
| 
 | ||||
| #define VDSO_HAS_CLOCK_GETRES		1 | ||||
| 
 | ||||
| #define __VDSO_USE_SYSCALL		ULLONG_MAX | ||||
| 
 | ||||
| #ifdef CONFIG_MIPS_CLOCK_VSYSCALL | ||||
| 
 | ||||
| static __always_inline long gettimeofday_fallback( | ||||
| @@ -205,7 +207,7 @@ static __always_inline u64 __arch_get_hw_counter(s32 clock_mode) | ||||
| 		break; | ||||
| #endif | ||||
| 	default: | ||||
| 		cycle_now = 0; | ||||
| 		cycle_now = __VDSO_USE_SYSCALL; | ||||
| 		break; | ||||
| 	} | ||||
| 
 | ||||
|   | ||||
| @@ -464,10 +464,10 @@ static void bmips_wr_vec(unsigned long dst, char *start, char *end) | ||||
| 
 | ||||
| static inline void bmips_nmi_handler_setup(void) | ||||
| { | ||||
| 	bmips_wr_vec(BMIPS_NMI_RESET_VEC, &bmips_reset_nmi_vec, | ||||
| 		&bmips_reset_nmi_vec_end); | ||||
| 	bmips_wr_vec(BMIPS_WARM_RESTART_VEC, &bmips_smp_int_vec, | ||||
| 		&bmips_smp_int_vec_end); | ||||
| 	bmips_wr_vec(BMIPS_NMI_RESET_VEC, bmips_reset_nmi_vec, | ||||
| 		bmips_reset_nmi_vec_end); | ||||
| 	bmips_wr_vec(BMIPS_WARM_RESTART_VEC, bmips_smp_int_vec, | ||||
| 		bmips_smp_int_vec_end); | ||||
| } | ||||
| 
 | ||||
| struct reset_vec_info { | ||||
|   | ||||
| @@ -653,6 +653,13 @@ static void build_restore_pagemask(u32 **p, struct uasm_reloc **r, | ||||
| 				   int restore_scratch) | ||||
| { | ||||
| 	if (restore_scratch) { | ||||
| 		/*
 | ||||
| 		 * Ensure the MFC0 below observes the value written to the | ||||
| 		 * KScratch register by the prior MTC0. | ||||
| 		 */ | ||||
| 		if (scratch_reg >= 0) | ||||
| 			uasm_i_ehb(p); | ||||
| 
 | ||||
| 		/* Reset default page size */ | ||||
| 		if (PM_DEFAULT_MASK >> 16) { | ||||
| 			uasm_i_lui(p, tmp, PM_DEFAULT_MASK >> 16); | ||||
| @@ -667,12 +674,10 @@ static void build_restore_pagemask(u32 **p, struct uasm_reloc **r, | ||||
| 			uasm_i_mtc0(p, 0, C0_PAGEMASK); | ||||
| 			uasm_il_b(p, r, lid); | ||||
| 		} | ||||
| 		if (scratch_reg >= 0) { | ||||
| 			uasm_i_ehb(p); | ||||
| 		if (scratch_reg >= 0) | ||||
| 			UASM_i_MFC0(p, 1, c0_kscratch(), scratch_reg); | ||||
| 		} else { | ||||
| 		else | ||||
| 			UASM_i_LW(p, 1, scratchpad_offset(0), 0); | ||||
| 		} | ||||
| 	} else { | ||||
| 		/* Reset default page size */ | ||||
| 		if (PM_DEFAULT_MASK >> 16) { | ||||
| @@ -921,6 +926,10 @@ build_get_pgd_vmalloc64(u32 **p, struct uasm_label **l, struct uasm_reloc **r, | ||||
| 	} | ||||
| 	if (mode != not_refill && check_for_high_segbits) { | ||||
| 		uasm_l_large_segbits_fault(l, *p); | ||||
| 
 | ||||
| 		if (mode == refill_scratch && scratch_reg >= 0) | ||||
| 			uasm_i_ehb(p); | ||||
| 
 | ||||
| 		/*
 | ||||
| 		 * We get here if we are an xsseg address, or if we are | ||||
| 		 * an xuseg address above (PGDIR_SHIFT+PGDIR_BITS) boundary. | ||||
| @@ -939,12 +948,10 @@ build_get_pgd_vmalloc64(u32 **p, struct uasm_label **l, struct uasm_reloc **r, | ||||
| 		uasm_i_jr(p, ptr); | ||||
| 
 | ||||
| 		if (mode == refill_scratch) { | ||||
| 			if (scratch_reg >= 0) { | ||||
| 				uasm_i_ehb(p); | ||||
| 			if (scratch_reg >= 0) | ||||
| 				UASM_i_MFC0(p, 1, c0_kscratch(), scratch_reg); | ||||
| 			} else { | ||||
| 			else | ||||
| 				UASM_i_LW(p, 1, scratchpad_offset(0), 0); | ||||
| 			} | ||||
| 		} else { | ||||
| 			uasm_i_nop(p); | ||||
| 		} | ||||
|   | ||||
| @@ -22,7 +22,7 @@ | ||||
| 
 | ||||
| #define ARCH_DMA_MINALIGN	L1_CACHE_BYTES | ||||
| 
 | ||||
| #define __read_mostly __attribute__((__section__(".data..read_mostly"))) | ||||
| #define __read_mostly __section(.data..read_mostly) | ||||
| 
 | ||||
| void parisc_cache_init(void);	/* initializes cache-flushing */ | ||||
| void disable_sr_hashing_asm(int); /* low level support for above */ | ||||
|   | ||||
| @@ -52,7 +52,7 @@ | ||||
| }) | ||||
| 
 | ||||
| #ifdef CONFIG_SMP | ||||
| # define __lock_aligned __attribute__((__section__(".data..lock_aligned"))) | ||||
| # define __lock_aligned __section(.data..lock_aligned) | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __PARISC_LDCW_H */ | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
|  * arch/parisc/mm/ioremap.c | ||||
|  * | ||||
|  * (C) Copyright 1995 1996 Linus Torvalds | ||||
|  * (C) Copyright 2001-2006 Helge Deller <deller@gmx.de> | ||||
|  * (C) Copyright 2001-2019 Helge Deller <deller@gmx.de> | ||||
|  * (C) Copyright 2005 Kyle McMartin <kyle@parisc-linux.org> | ||||
|  */ | ||||
| 
 | ||||
| @@ -84,7 +84,7 @@ void __iomem * __ioremap(unsigned long phys_addr, unsigned long size, unsigned l | ||||
| 	addr = (void __iomem *) area->addr; | ||||
| 	if (ioremap_page_range((unsigned long)addr, (unsigned long)addr + size, | ||||
| 			       phys_addr, pgprot)) { | ||||
| 		vfree(addr); | ||||
| 		vunmap(addr); | ||||
| 		return NULL; | ||||
| 	} | ||||
| 
 | ||||
| @@ -92,9 +92,11 @@ void __iomem * __ioremap(unsigned long phys_addr, unsigned long size, unsigned l | ||||
| } | ||||
| EXPORT_SYMBOL(__ioremap); | ||||
| 
 | ||||
| void iounmap(const volatile void __iomem *addr) | ||||
| void iounmap(const volatile void __iomem *io_addr) | ||||
| { | ||||
| 	if (addr > high_memory) | ||||
| 		return vfree((void *) (PAGE_MASK & (unsigned long __force) addr)); | ||||
| 	unsigned long addr = (unsigned long)io_addr & PAGE_MASK; | ||||
| 
 | ||||
| 	if (is_vmalloc_addr((void *)addr)) | ||||
| 		vunmap((void *)addr); | ||||
| } | ||||
| EXPORT_SYMBOL(iounmap); | ||||
|   | ||||
| @@ -1217,6 +1217,7 @@ int kvmppc_xive_connect_vcpu(struct kvm_device *dev, | ||||
| 	struct kvmppc_xive *xive = dev->private; | ||||
| 	struct kvmppc_xive_vcpu *xc; | ||||
| 	int i, r = -EBUSY; | ||||
| 	u32 vp_id; | ||||
| 
 | ||||
| 	pr_devel("connect_vcpu(cpu=%d)\n", cpu); | ||||
| 
 | ||||
| @@ -1228,25 +1229,32 @@ int kvmppc_xive_connect_vcpu(struct kvm_device *dev, | ||||
| 		return -EPERM; | ||||
| 	if (vcpu->arch.irq_type != KVMPPC_IRQ_DEFAULT) | ||||
| 		return -EBUSY; | ||||
| 	if (kvmppc_xive_find_server(vcpu->kvm, cpu)) { | ||||
| 		pr_devel("Duplicate !\n"); | ||||
| 		return -EEXIST; | ||||
| 	} | ||||
| 	if (cpu >= (KVM_MAX_VCPUS * vcpu->kvm->arch.emul_smt_mode)) { | ||||
| 		pr_devel("Out of bounds !\n"); | ||||
| 		return -EINVAL; | ||||
| 	} | ||||
| 	xc = kzalloc(sizeof(*xc), GFP_KERNEL); | ||||
| 	if (!xc) | ||||
| 		return -ENOMEM; | ||||
| 
 | ||||
| 	/* We need to synchronize with queue provisioning */ | ||||
| 	mutex_lock(&xive->lock); | ||||
| 
 | ||||
| 	vp_id = kvmppc_xive_vp(xive, cpu); | ||||
| 	if (kvmppc_xive_vp_in_use(xive->kvm, vp_id)) { | ||||
| 		pr_devel("Duplicate !\n"); | ||||
| 		r = -EEXIST; | ||||
| 		goto bail; | ||||
| 	} | ||||
| 
 | ||||
| 	xc = kzalloc(sizeof(*xc), GFP_KERNEL); | ||||
| 	if (!xc) { | ||||
| 		r = -ENOMEM; | ||||
| 		goto bail; | ||||
| 	} | ||||
| 
 | ||||
| 	vcpu->arch.xive_vcpu = xc; | ||||
| 	xc->xive = xive; | ||||
| 	xc->vcpu = vcpu; | ||||
| 	xc->server_num = cpu; | ||||
| 	xc->vp_id = kvmppc_xive_vp(xive, cpu); | ||||
| 	xc->vp_id = vp_id; | ||||
| 	xc->mfrr = 0xff; | ||||
| 	xc->valid = true; | ||||
| 
 | ||||
|   | ||||
| @@ -220,6 +220,18 @@ static inline u32 kvmppc_xive_vp(struct kvmppc_xive *xive, u32 server) | ||||
| 	return xive->vp_base + kvmppc_pack_vcpu_id(xive->kvm, server); | ||||
| } | ||||
| 
 | ||||
| static inline bool kvmppc_xive_vp_in_use(struct kvm *kvm, u32 vp_id) | ||||
| { | ||||
| 	struct kvm_vcpu *vcpu = NULL; | ||||
| 	int i; | ||||
| 
 | ||||
| 	kvm_for_each_vcpu(i, vcpu, kvm) { | ||||
| 		if (vcpu->arch.xive_vcpu && vp_id == vcpu->arch.xive_vcpu->vp_id) | ||||
| 			return true; | ||||
| 	} | ||||
| 	return false; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Mapping between guest priorities and host priorities | ||||
|  * is as follow. | ||||
|   | ||||
| @@ -106,6 +106,7 @@ int kvmppc_xive_native_connect_vcpu(struct kvm_device *dev, | ||||
| 	struct kvmppc_xive *xive = dev->private; | ||||
| 	struct kvmppc_xive_vcpu *xc = NULL; | ||||
| 	int rc; | ||||
| 	u32 vp_id; | ||||
| 
 | ||||
| 	pr_devel("native_connect_vcpu(server=%d)\n", server_num); | ||||
| 
 | ||||
| @@ -124,7 +125,8 @@ int kvmppc_xive_native_connect_vcpu(struct kvm_device *dev, | ||||
| 
 | ||||
| 	mutex_lock(&xive->lock); | ||||
| 
 | ||||
| 	if (kvmppc_xive_find_server(vcpu->kvm, server_num)) { | ||||
| 	vp_id = kvmppc_xive_vp(xive, server_num); | ||||
| 	if (kvmppc_xive_vp_in_use(xive->kvm, vp_id)) { | ||||
| 		pr_devel("Duplicate !\n"); | ||||
| 		rc = -EEXIST; | ||||
| 		goto bail; | ||||
| @@ -141,7 +143,7 @@ int kvmppc_xive_native_connect_vcpu(struct kvm_device *dev, | ||||
| 	xc->vcpu = vcpu; | ||||
| 	xc->server_num = server_num; | ||||
| 
 | ||||
| 	xc->vp_id = kvmppc_xive_vp(xive, server_num); | ||||
| 	xc->vp_id = vp_id; | ||||
| 	xc->valid = true; | ||||
| 	vcpu->arch.irq_type = KVMPPC_IRQ_XIVE; | ||||
| 
 | ||||
|   | ||||
| @@ -13,6 +13,7 @@ | ||||
| 	compatible = "sifive,hifive-unleashed-a00", "sifive,fu540-c000"; | ||||
|  | ||||
| 	chosen { | ||||
| 		stdout-path = "serial0"; | ||||
| 	}; | ||||
|  | ||||
| 	cpus { | ||||
|   | ||||
| @@ -12,7 +12,6 @@ | ||||
| 
 | ||||
| #include <asm/asm.h> | ||||
| 
 | ||||
| #ifdef CONFIG_GENERIC_BUG | ||||
| #define __INSN_LENGTH_MASK  _UL(0x3) | ||||
| #define __INSN_LENGTH_32    _UL(0x3) | ||||
| #define __COMPRESSED_INSN_MASK	_UL(0xffff) | ||||
| @@ -20,7 +19,6 @@ | ||||
| #define __BUG_INSN_32	_UL(0x00100073) /* ebreak */ | ||||
| #define __BUG_INSN_16	_UL(0x9002) /* c.ebreak */ | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| typedef u32 bug_insn_t; | ||||
| 
 | ||||
| #ifdef CONFIG_GENERIC_BUG_RELATIVE_POINTERS | ||||
| @@ -43,6 +41,7 @@ typedef u32 bug_insn_t; | ||||
| 	RISCV_SHORT " %2" | ||||
| #endif | ||||
| 
 | ||||
| #ifdef CONFIG_GENERIC_BUG | ||||
| #define __BUG_FLAGS(flags)					\ | ||||
| do {								\ | ||||
| 	__asm__ __volatile__ (					\ | ||||
| @@ -58,14 +57,10 @@ do {								\ | ||||
| 		  "i" (flags),					\ | ||||
| 		  "i" (sizeof(struct bug_entry)));              \ | ||||
| } while (0) | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #else /* CONFIG_GENERIC_BUG */ | ||||
| #ifndef __ASSEMBLY__ | ||||
| #define __BUG_FLAGS(flags) do {					\ | ||||
| 	__asm__ __volatile__ ("ebreak\n");			\ | ||||
| } while (0) | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* CONFIG_GENERIC_BUG */ | ||||
| 
 | ||||
| #define BUG() do {						\ | ||||
| @@ -79,15 +74,10 @@ do {								\ | ||||
| 
 | ||||
| #include <asm-generic/bug.h> | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| 
 | ||||
| struct pt_regs; | ||||
| struct task_struct; | ||||
| 
 | ||||
| extern void die(struct pt_regs *regs, const char *str); | ||||
| extern void do_trap(struct pt_regs *regs, int signo, int code, | ||||
| 	unsigned long addr); | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| void die(struct pt_regs *regs, const char *str); | ||||
| void do_trap(struct pt_regs *regs, int signo, int code, unsigned long addr); | ||||
| 
 | ||||
| #endif /* _ASM_RISCV_BUG_H */ | ||||
|   | ||||
| @@ -87,14 +87,6 @@ extern pgd_t swapper_pg_dir[]; | ||||
| #define VMALLOC_END      (PAGE_OFFSET - 1) | ||||
| #define VMALLOC_START    (PAGE_OFFSET - VMALLOC_SIZE) | ||||
| 
 | ||||
| #define FIXADDR_TOP      VMALLOC_START | ||||
| #ifdef CONFIG_64BIT | ||||
| #define FIXADDR_SIZE     PMD_SIZE | ||||
| #else | ||||
| #define FIXADDR_SIZE     PGDIR_SIZE | ||||
| #endif | ||||
| #define FIXADDR_START    (FIXADDR_TOP - FIXADDR_SIZE) | ||||
| 
 | ||||
| /*
 | ||||
|  * Roughly size the vmemmap space to be large enough to fit enough | ||||
|  * struct pages to map half the virtual address space. Then | ||||
| @@ -108,6 +100,14 @@ extern pgd_t swapper_pg_dir[]; | ||||
| 
 | ||||
| #define vmemmap		((struct page *)VMEMMAP_START) | ||||
| 
 | ||||
| #define FIXADDR_TOP      (VMEMMAP_START) | ||||
| #ifdef CONFIG_64BIT | ||||
| #define FIXADDR_SIZE     PMD_SIZE | ||||
| #else | ||||
| #define FIXADDR_SIZE     PGDIR_SIZE | ||||
| #endif | ||||
| #define FIXADDR_START    (FIXADDR_TOP - FIXADDR_SIZE) | ||||
| 
 | ||||
| /*
 | ||||
|  * ZERO_PAGE is a global shared page that is always zero, | ||||
|  * used for zero-mapped memory areas, etc. | ||||
| @@ -184,10 +184,7 @@ static inline pte_t pfn_pte(unsigned long pfn, pgprot_t prot) | ||||
| 	return __pte((pfn << _PAGE_PFN_SHIFT) | pgprot_val(prot)); | ||||
| } | ||||
| 
 | ||||
| static inline pte_t mk_pte(struct page *page, pgprot_t prot) | ||||
| { | ||||
| 	return pfn_pte(page_to_pfn(page), prot); | ||||
| } | ||||
| #define mk_pte(page, prot)       pfn_pte(page_to_pfn(page), prot) | ||||
| 
 | ||||
| #define pte_index(addr) (((addr) >> PAGE_SHIFT) & (PTRS_PER_PTE - 1)) | ||||
| 
 | ||||
| @@ -428,9 +425,7 @@ static inline int ptep_clear_flush_young(struct vm_area_struct *vma, | ||||
| #define __pte_to_swp_entry(pte)	((swp_entry_t) { pte_val(pte) }) | ||||
| #define __swp_entry_to_pte(x)	((pte_t) { (x).val }) | ||||
| 
 | ||||
| #ifdef CONFIG_FLATMEM | ||||
| #define kern_addr_valid(addr)   (1) /* FIXME */ | ||||
| #endif | ||||
| 
 | ||||
| extern void *dtb_early_va; | ||||
| extern void setup_bootmem(void); | ||||
|   | ||||
| @@ -10,10 +10,6 @@ | ||||
| #include <linux/mm_types.h> | ||||
| #include <asm/smp.h> | ||||
| 
 | ||||
| /*
 | ||||
|  * Flush entire local TLB.  'sfence.vma' implicitly fences with the instruction | ||||
|  * cache as well, so a 'fence.i' is not necessary. | ||||
|  */ | ||||
| static inline void local_flush_tlb_all(void) | ||||
| { | ||||
| 	__asm__ __volatile__ ("sfence.vma" : : : "memory"); | ||||
|   | ||||
| @@ -111,7 +111,6 @@ DO_ERROR_INFO(do_trap_ecall_s, | ||||
| DO_ERROR_INFO(do_trap_ecall_m, | ||||
| 	SIGILL, ILL_ILLTRP, "environment call from M-mode"); | ||||
| 
 | ||||
| #ifdef CONFIG_GENERIC_BUG | ||||
| static inline unsigned long get_break_insn_length(unsigned long pc) | ||||
| { | ||||
| 	bug_insn_t insn; | ||||
| @@ -120,28 +119,15 @@ static inline unsigned long get_break_insn_length(unsigned long pc) | ||||
| 		return 0; | ||||
| 	return (((insn & __INSN_LENGTH_MASK) == __INSN_LENGTH_32) ? 4UL : 2UL); | ||||
| } | ||||
| #endif /* CONFIG_GENERIC_BUG */ | ||||
| 
 | ||||
| asmlinkage void do_trap_break(struct pt_regs *regs) | ||||
| { | ||||
| 	if (!user_mode(regs)) { | ||||
| 		enum bug_trap_type type; | ||||
| 
 | ||||
| 		type = report_bug(regs->sepc, regs); | ||||
| 		switch (type) { | ||||
| #ifdef CONFIG_GENERIC_BUG | ||||
| 		case BUG_TRAP_TYPE_WARN: | ||||
| 			regs->sepc += get_break_insn_length(regs->sepc); | ||||
| 			return; | ||||
| 		case BUG_TRAP_TYPE_BUG: | ||||
| #endif /* CONFIG_GENERIC_BUG */ | ||||
| 		default: | ||||
| 			die(regs, "Kernel BUG"); | ||||
| 		} | ||||
| 	} else { | ||||
| 		force_sig_fault(SIGTRAP, TRAP_BRKPT, | ||||
| 				(void __user *)(regs->sepc)); | ||||
| 	} | ||||
| 	if (user_mode(regs)) | ||||
| 		force_sig_fault(SIGTRAP, TRAP_BRKPT, (void __user *)regs->sepc); | ||||
| 	else if (report_bug(regs->sepc, regs) == BUG_TRAP_TYPE_WARN) | ||||
| 		regs->sepc += get_break_insn_length(regs->sepc); | ||||
| 	else | ||||
| 		die(regs, "Kernel BUG"); | ||||
| } | ||||
| 
 | ||||
| #ifdef CONFIG_GENERIC_BUG | ||||
|   | ||||
| @@ -458,7 +458,7 @@ void __init paging_init(void) | ||||
| 	zone_sizes_init(); | ||||
| } | ||||
| 
 | ||||
| #ifdef CONFIG_SPARSEMEM | ||||
| #ifdef CONFIG_SPARSEMEM_VMEMMAP | ||||
| int __meminit vmemmap_populate(unsigned long start, unsigned long end, int node, | ||||
| 			       struct vmem_altmap *altmap) | ||||
| { | ||||
|   | ||||
| @@ -101,10 +101,18 @@ static void handle_relocs(unsigned long offset) | ||||
| 	dynsym = (Elf64_Sym *) vmlinux.dynsym_start; | ||||
| 	for (rela = rela_start; rela < rela_end; rela++) { | ||||
| 		loc = rela->r_offset + offset; | ||||
| 		val = rela->r_addend + offset; | ||||
| 		val = rela->r_addend; | ||||
| 		r_sym = ELF64_R_SYM(rela->r_info); | ||||
| 		if (r_sym) | ||||
| 			val += dynsym[r_sym].st_value; | ||||
| 		if (r_sym) { | ||||
| 			if (dynsym[r_sym].st_shndx != SHN_UNDEF) | ||||
| 				val += dynsym[r_sym].st_value + offset; | ||||
| 		} else { | ||||
| 			/*
 | ||||
| 			 * 0 == undefined symbol table index (STN_UNDEF), | ||||
| 			 * used for R_390_RELATIVE, only add KASLR offset | ||||
| 			 */ | ||||
| 			val += offset; | ||||
| 		} | ||||
| 		r_type = ELF64_R_TYPE(rela->r_info); | ||||
| 		rc = arch_kexec_do_relocs(r_type, (void *) loc, val, 0); | ||||
| 		if (rc) | ||||
|   | ||||
| @@ -27,6 +27,7 @@ int arch_kexec_do_relocs(int r_type, void *loc, unsigned long val, | ||||
| 		*(u32 *)loc = val; | ||||
| 		break; | ||||
| 	case R_390_64:		/* Direct 64 bit.  */ | ||||
| 	case R_390_GLOB_DAT: | ||||
| 		*(u64 *)loc = val; | ||||
| 		break; | ||||
| 	case R_390_PC16:	/* PC relative 16 bit.	*/ | ||||
|   | ||||
| @@ -29,7 +29,6 @@ config SPARC | ||||
| 	select RTC_DRV_M48T59 | ||||
| 	select RTC_SYSTOHC | ||||
| 	select HAVE_ARCH_JUMP_LABEL if SPARC64 | ||||
| 	select HAVE_FAST_GUP if SPARC64 | ||||
| 	select GENERIC_IRQ_SHOW | ||||
| 	select ARCH_WANT_IPC_PARSE_VERSION | ||||
| 	select GENERIC_PCI_IOMAP | ||||
|   | ||||
| @@ -20,30 +20,6 @@ | ||||
|  */ | ||||
| struct mem_vector immovable_mem[MAX_NUMNODES*2]; | ||||
| 
 | ||||
| /*
 | ||||
|  * Max length of 64-bit hex address string is 19, prefix "0x" + 16 hex | ||||
|  * digits, and '\0' for termination. | ||||
|  */ | ||||
| #define MAX_ADDR_LEN 19 | ||||
| 
 | ||||
| static acpi_physical_address get_cmdline_acpi_rsdp(void) | ||||
| { | ||||
| 	acpi_physical_address addr = 0; | ||||
| 
 | ||||
| #ifdef CONFIG_KEXEC | ||||
| 	char val[MAX_ADDR_LEN] = { }; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	ret = cmdline_find_option("acpi_rsdp", val, MAX_ADDR_LEN); | ||||
| 	if (ret < 0) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	if (kstrtoull(val, 16, &addr)) | ||||
| 		return 0; | ||||
| #endif | ||||
| 	return addr; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * Search EFI system tables for RSDP.  If both ACPI_20_TABLE_GUID and | ||||
|  * ACPI_TABLE_GUID are found, take the former, which has more features. | ||||
| @@ -298,6 +274,30 @@ acpi_physical_address get_rsdp_addr(void) | ||||
| } | ||||
| 
 | ||||
| #if defined(CONFIG_RANDOMIZE_BASE) && defined(CONFIG_MEMORY_HOTREMOVE) | ||||
| /*
 | ||||
|  * Max length of 64-bit hex address string is 19, prefix "0x" + 16 hex | ||||
|  * digits, and '\0' for termination. | ||||
|  */ | ||||
| #define MAX_ADDR_LEN 19 | ||||
| 
 | ||||
| static acpi_physical_address get_cmdline_acpi_rsdp(void) | ||||
| { | ||||
| 	acpi_physical_address addr = 0; | ||||
| 
 | ||||
| #ifdef CONFIG_KEXEC | ||||
| 	char val[MAX_ADDR_LEN] = { }; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	ret = cmdline_find_option("acpi_rsdp", val, MAX_ADDR_LEN); | ||||
| 	if (ret < 0) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	if (kstrtoull(val, 16, &addr)) | ||||
| 		return 0; | ||||
| #endif | ||||
| 	return addr; | ||||
| } | ||||
| 
 | ||||
| /* Compute SRAT address from RSDP. */ | ||||
| static unsigned long get_acpi_srat_table(void) | ||||
| { | ||||
|   | ||||
| @@ -345,6 +345,7 @@ asmlinkage __visible void *extract_kernel(void *rmode, memptr heap, | ||||
| { | ||||
| 	const unsigned long kernel_total_size = VO__end - VO__text; | ||||
| 	unsigned long virt_addr = LOAD_PHYSICAL_ADDR; | ||||
| 	unsigned long needed_size; | ||||
| 
 | ||||
| 	/* Retain x86 boot parameters pointer passed from startup_32/64. */ | ||||
| 	boot_params = rmode; | ||||
| @@ -379,26 +380,38 @@ asmlinkage __visible void *extract_kernel(void *rmode, memptr heap, | ||||
| 	free_mem_ptr     = heap;	/* Heap */ | ||||
| 	free_mem_end_ptr = heap + BOOT_HEAP_SIZE; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * The memory hole needed for the kernel is the larger of either | ||||
| 	 * the entire decompressed kernel plus relocation table, or the | ||||
| 	 * entire decompressed kernel plus .bss and .brk sections. | ||||
| 	 * | ||||
| 	 * On X86_64, the memory is mapped with PMD pages. Round the | ||||
| 	 * size up so that the full extent of PMD pages mapped is | ||||
| 	 * included in the check against the valid memory table | ||||
| 	 * entries. This ensures the full mapped area is usable RAM | ||||
| 	 * and doesn't include any reserved areas. | ||||
| 	 */ | ||||
| 	needed_size = max(output_len, kernel_total_size); | ||||
| #ifdef CONFIG_X86_64 | ||||
| 	needed_size = ALIGN(needed_size, MIN_KERNEL_ALIGN); | ||||
| #endif | ||||
| 
 | ||||
| 	/* Report initial kernel position details. */ | ||||
| 	debug_putaddr(input_data); | ||||
| 	debug_putaddr(input_len); | ||||
| 	debug_putaddr(output); | ||||
| 	debug_putaddr(output_len); | ||||
| 	debug_putaddr(kernel_total_size); | ||||
| 	debug_putaddr(needed_size); | ||||
| 
 | ||||
| #ifdef CONFIG_X86_64 | ||||
| 	/* Report address of 32-bit trampoline */ | ||||
| 	debug_putaddr(trampoline_32bit); | ||||
| #endif | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * The memory hole needed for the kernel is the larger of either | ||||
| 	 * the entire decompressed kernel plus relocation table, or the | ||||
| 	 * entire decompressed kernel plus .bss and .brk sections. | ||||
| 	 */ | ||||
| 	choose_random_location((unsigned long)input_data, input_len, | ||||
| 				(unsigned long *)&output, | ||||
| 				max(output_len, kernel_total_size), | ||||
| 				needed_size, | ||||
| 				&virt_addr); | ||||
| 
 | ||||
| 	/* Validate memory location choices. */ | ||||
|   | ||||
| @@ -377,7 +377,8 @@ static inline void perf_ibs_disable_event(struct perf_ibs *perf_ibs, | ||||
| 					  struct hw_perf_event *hwc, u64 config) | ||||
| { | ||||
| 	config &= ~perf_ibs->cnt_mask; | ||||
| 	wrmsrl(hwc->config_base, config); | ||||
| 	if (boot_cpu_data.x86 == 0x10) | ||||
| 		wrmsrl(hwc->config_base, config); | ||||
| 	config &= ~perf_ibs->enable_mask; | ||||
| 	wrmsrl(hwc->config_base, config); | ||||
| } | ||||
| @@ -553,7 +554,8 @@ static struct perf_ibs perf_ibs_op = { | ||||
| 	}, | ||||
| 	.msr			= MSR_AMD64_IBSOPCTL, | ||||
| 	.config_mask		= IBS_OP_CONFIG_MASK, | ||||
| 	.cnt_mask		= IBS_OP_MAX_CNT, | ||||
| 	.cnt_mask		= IBS_OP_MAX_CNT | IBS_OP_CUR_CNT | | ||||
| 				  IBS_OP_CUR_CNT_RAND, | ||||
| 	.enable_mask		= IBS_OP_ENABLE, | ||||
| 	.valid_mask		= IBS_OP_VAL, | ||||
| 	.max_period		= IBS_OP_MAX_CNT << 4, | ||||
| @@ -614,7 +616,7 @@ fail: | ||||
| 	if (event->attr.sample_type & PERF_SAMPLE_RAW) | ||||
| 		offset_max = perf_ibs->offset_max; | ||||
| 	else if (check_rip) | ||||
| 		offset_max = 2; | ||||
| 		offset_max = 3; | ||||
| 	else | ||||
| 		offset_max = 1; | ||||
| 	do { | ||||
|   | ||||
| @@ -502,10 +502,8 @@ void uncore_pmu_event_start(struct perf_event *event, int flags) | ||||
| 	local64_set(&event->hw.prev_count, uncore_read_counter(box, event)); | ||||
| 	uncore_enable_event(box, event); | ||||
| 
 | ||||
| 	if (box->n_active == 1) { | ||||
| 		uncore_enable_box(box); | ||||
| 	if (box->n_active == 1) | ||||
| 		uncore_pmu_start_hrtimer(box); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void uncore_pmu_event_stop(struct perf_event *event, int flags) | ||||
| @@ -529,10 +527,8 @@ void uncore_pmu_event_stop(struct perf_event *event, int flags) | ||||
| 		WARN_ON_ONCE(hwc->state & PERF_HES_STOPPED); | ||||
| 		hwc->state |= PERF_HES_STOPPED; | ||||
| 
 | ||||
| 		if (box->n_active == 0) { | ||||
| 			uncore_disable_box(box); | ||||
| 		if (box->n_active == 0) | ||||
| 			uncore_pmu_cancel_hrtimer(box); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	if ((flags & PERF_EF_UPDATE) && !(hwc->state & PERF_HES_UPTODATE)) { | ||||
| @@ -778,6 +774,40 @@ static int uncore_pmu_event_init(struct perf_event *event) | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| static void uncore_pmu_enable(struct pmu *pmu) | ||||
| { | ||||
| 	struct intel_uncore_pmu *uncore_pmu; | ||||
| 	struct intel_uncore_box *box; | ||||
| 
 | ||||
| 	uncore_pmu = container_of(pmu, struct intel_uncore_pmu, pmu); | ||||
| 	if (!uncore_pmu) | ||||
| 		return; | ||||
| 
 | ||||
| 	box = uncore_pmu_to_box(uncore_pmu, smp_processor_id()); | ||||
| 	if (!box) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (uncore_pmu->type->ops->enable_box) | ||||
| 		uncore_pmu->type->ops->enable_box(box); | ||||
| } | ||||
| 
 | ||||
| static void uncore_pmu_disable(struct pmu *pmu) | ||||
| { | ||||
| 	struct intel_uncore_pmu *uncore_pmu; | ||||
| 	struct intel_uncore_box *box; | ||||
| 
 | ||||
| 	uncore_pmu = container_of(pmu, struct intel_uncore_pmu, pmu); | ||||
| 	if (!uncore_pmu) | ||||
| 		return; | ||||
| 
 | ||||
| 	box = uncore_pmu_to_box(uncore_pmu, smp_processor_id()); | ||||
| 	if (!box) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (uncore_pmu->type->ops->disable_box) | ||||
| 		uncore_pmu->type->ops->disable_box(box); | ||||
| } | ||||
| 
 | ||||
| static ssize_t uncore_get_attr_cpumask(struct device *dev, | ||||
| 				struct device_attribute *attr, char *buf) | ||||
| { | ||||
| @@ -803,6 +833,8 @@ static int uncore_pmu_register(struct intel_uncore_pmu *pmu) | ||||
| 		pmu->pmu = (struct pmu) { | ||||
| 			.attr_groups	= pmu->type->attr_groups, | ||||
| 			.task_ctx_nr	= perf_invalid_context, | ||||
| 			.pmu_enable	= uncore_pmu_enable, | ||||
| 			.pmu_disable	= uncore_pmu_disable, | ||||
| 			.event_init	= uncore_pmu_event_init, | ||||
| 			.add		= uncore_pmu_event_add, | ||||
| 			.del		= uncore_pmu_event_del, | ||||
|   | ||||
| @@ -441,18 +441,6 @@ static inline int uncore_freerunning_hw_config(struct intel_uncore_box *box, | ||||
| 	return -EINVAL; | ||||
| } | ||||
| 
 | ||||
| static inline void uncore_disable_box(struct intel_uncore_box *box) | ||||
| { | ||||
| 	if (box->pmu->type->ops->disable_box) | ||||
| 		box->pmu->type->ops->disable_box(box); | ||||
| } | ||||
| 
 | ||||
| static inline void uncore_enable_box(struct intel_uncore_box *box) | ||||
| { | ||||
| 	if (box->pmu->type->ops->enable_box) | ||||
| 		box->pmu->type->ops->enable_box(box); | ||||
| } | ||||
| 
 | ||||
| static inline void uncore_disable_event(struct intel_uncore_box *box, | ||||
| 				struct perf_event *event) | ||||
| { | ||||
|   | ||||
| @@ -260,11 +260,21 @@ void __init hv_apic_init(void) | ||||
| 	} | ||||
| 
 | ||||
| 	if (ms_hyperv.hints & HV_X64_APIC_ACCESS_RECOMMENDED) { | ||||
| 		pr_info("Hyper-V: Using MSR based APIC access\n"); | ||||
| 		pr_info("Hyper-V: Using enlightened APIC (%s mode)", | ||||
| 			x2apic_enabled() ? "x2apic" : "xapic"); | ||||
| 		/*
 | ||||
| 		 * With x2apic, architectural x2apic MSRs are equivalent to the | ||||
| 		 * respective synthetic MSRs, so there's no need to override | ||||
| 		 * the apic accessors.  The only exception is | ||||
| 		 * hv_apic_eoi_write, because it benefits from lazy EOI when | ||||
| 		 * available, but it works for both xapic and x2apic modes. | ||||
| 		 */ | ||||
| 		apic_set_eoi_write(hv_apic_eoi_write); | ||||
| 		apic->read      = hv_apic_read; | ||||
| 		apic->write     = hv_apic_write; | ||||
| 		apic->icr_write = hv_apic_icr_write; | ||||
| 		apic->icr_read  = hv_apic_icr_read; | ||||
| 		if (!x2apic_enabled()) { | ||||
| 			apic->read      = hv_apic_read; | ||||
| 			apic->write     = hv_apic_write; | ||||
| 			apic->icr_write = hv_apic_icr_write; | ||||
| 			apic->icr_read  = hv_apic_icr_read; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -1189,7 +1189,7 @@ struct kvm_x86_ops { | ||||
| 	int (*set_nested_state)(struct kvm_vcpu *vcpu, | ||||
| 				struct kvm_nested_state __user *user_kvm_nested_state, | ||||
| 				struct kvm_nested_state *kvm_state); | ||||
| 	void (*get_vmcs12_pages)(struct kvm_vcpu *vcpu); | ||||
| 	bool (*get_vmcs12_pages)(struct kvm_vcpu *vcpu); | ||||
| 
 | ||||
| 	int (*smi_allowed)(struct kvm_vcpu *vcpu); | ||||
| 	int (*pre_enter_smm)(struct kvm_vcpu *vcpu, char *smstate); | ||||
|   | ||||
| @@ -4,6 +4,7 @@ | ||||
| 
 | ||||
| #include <asm/cpufeatures.h> | ||||
| #include <asm/alternative.h> | ||||
| #include <linux/stringify.h> | ||||
| 
 | ||||
| /*
 | ||||
|  * The hypercall definitions differ in the low word of the %edx argument | ||||
| @@ -20,8 +21,8 @@ | ||||
|  */ | ||||
| 
 | ||||
| /* Old port-based version */ | ||||
| #define VMWARE_HYPERVISOR_PORT    "0x5658" | ||||
| #define VMWARE_HYPERVISOR_PORT_HB "0x5659" | ||||
| #define VMWARE_HYPERVISOR_PORT    0x5658 | ||||
| #define VMWARE_HYPERVISOR_PORT_HB 0x5659 | ||||
| 
 | ||||
| /* Current vmcall / vmmcall version */ | ||||
| #define VMWARE_HYPERVISOR_HB   BIT(0) | ||||
| @@ -29,7 +30,8 @@ | ||||
| 
 | ||||
| /* The low bandwidth call. The low word of edx is presumed clear. */ | ||||
| #define VMWARE_HYPERCALL						\ | ||||
| 	ALTERNATIVE_2("movw $" VMWARE_HYPERVISOR_PORT ", %%dx; inl (%%dx)", \ | ||||
| 	ALTERNATIVE_2("movw $" __stringify(VMWARE_HYPERVISOR_PORT) ", %%dx; " \ | ||||
| 		      "inl (%%dx), %%eax",				\ | ||||
| 		      "vmcall", X86_FEATURE_VMCALL,			\ | ||||
| 		      "vmmcall", X86_FEATURE_VMW_VMMCALL) | ||||
| 
 | ||||
| @@ -38,7 +40,8 @@ | ||||
|  * HB and OUT bits set. | ||||
|  */ | ||||
| #define VMWARE_HYPERCALL_HB_OUT						\ | ||||
| 	ALTERNATIVE_2("movw $" VMWARE_HYPERVISOR_PORT_HB ", %%dx; rep outsb", \ | ||||
| 	ALTERNATIVE_2("movw $" __stringify(VMWARE_HYPERVISOR_PORT_HB) ", %%dx; " \ | ||||
| 		      "rep outsb",					\ | ||||
| 		      "vmcall", X86_FEATURE_VMCALL,			\ | ||||
| 		      "vmmcall", X86_FEATURE_VMW_VMMCALL) | ||||
| 
 | ||||
| @@ -47,7 +50,8 @@ | ||||
|  * HB bit set. | ||||
|  */ | ||||
| #define VMWARE_HYPERCALL_HB_IN						\ | ||||
| 	ALTERNATIVE_2("movw $" VMWARE_HYPERVISOR_PORT_HB ", %%dx; rep insb", \ | ||||
| 	ALTERNATIVE_2("movw $" __stringify(VMWARE_HYPERVISOR_PORT_HB) ", %%dx; " \ | ||||
| 		      "rep insb",					\ | ||||
| 		      "vmcall", X86_FEATURE_VMCALL,			\ | ||||
| 		      "vmmcall", X86_FEATURE_VMW_VMMCALL) | ||||
| #endif | ||||
|   | ||||
| @@ -156,7 +156,8 @@ static int x2apic_dead_cpu(unsigned int dead_cpu) | ||||
| { | ||||
| 	struct cluster_mask *cmsk = per_cpu(cluster_masks, dead_cpu); | ||||
| 
 | ||||
| 	cpumask_clear_cpu(dead_cpu, &cmsk->mask); | ||||
| 	if (cmsk) | ||||
| 		cpumask_clear_cpu(dead_cpu, &cmsk->mask); | ||||
| 	free_cpumask_var(per_cpu(ipi_mask, dead_cpu)); | ||||
| 	return 0; | ||||
| } | ||||
|   | ||||
| @@ -216,6 +216,10 @@ static void __init ms_hyperv_init_platform(void) | ||||
| 	int hv_host_info_ecx; | ||||
| 	int hv_host_info_edx; | ||||
| 
 | ||||
| #ifdef CONFIG_PARAVIRT | ||||
| 	pv_info.name = "Hyper-V"; | ||||
| #endif | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * Extract the features and hints | ||||
| 	 */ | ||||
|   | ||||
| @@ -222,13 +222,31 @@ unsigned long __head __startup_64(unsigned long physaddr, | ||||
| 	 * we might write invalid pmds, when the kernel is relocated | ||||
| 	 * cleanup_highmap() fixes this up along with the mappings | ||||
| 	 * beyond _end. | ||||
| 	 * | ||||
| 	 * Only the region occupied by the kernel image has so far | ||||
| 	 * been checked against the table of usable memory regions | ||||
| 	 * provided by the firmware, so invalidate pages outside that | ||||
| 	 * region. A page table entry that maps to a reserved area of | ||||
| 	 * memory would allow processor speculation into that area, | ||||
| 	 * and on some hardware (particularly the UV platform) even | ||||
| 	 * speculative access to some reserved areas is caught as an | ||||
| 	 * error, causing the BIOS to halt the system. | ||||
| 	 */ | ||||
| 
 | ||||
| 	pmd = fixup_pointer(level2_kernel_pgt, physaddr); | ||||
| 	for (i = 0; i < PTRS_PER_PMD; i++) { | ||||
| 
 | ||||
| 	/* invalidate pages before the kernel image */ | ||||
| 	for (i = 0; i < pmd_index((unsigned long)_text); i++) | ||||
| 		pmd[i] &= ~_PAGE_PRESENT; | ||||
| 
 | ||||
| 	/* fixup pages that are part of the kernel image */ | ||||
| 	for (; i <= pmd_index((unsigned long)_end); i++) | ||||
| 		if (pmd[i] & _PAGE_PRESENT) | ||||
| 			pmd[i] += load_delta; | ||||
| 	} | ||||
| 
 | ||||
| 	/* invalidate pages after the kernel image */ | ||||
| 	for (; i < PTRS_PER_PMD; i++) | ||||
| 		pmd[i] &= ~_PAGE_PRESENT; | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * Fixup phys_base - remove the memory encryption mask to obtain | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user