kernel: bump 4.14 to 4.14.171
Refreshed all patches. Fixes: - CVE-2013-1798 Compile-tested on: cns3xxx Runtime-tested on: cns3xxx Signed-off-by: Koen Vandeputte <koen.vandeputte@ncentric.com>
This commit is contained in:
		| @@ -6,10 +6,10 @@ ifdef CONFIG_TESTING_KERNEL | |||||||
|   KERNEL_PATCHVER:=$(KERNEL_TESTING_PATCHVER) |   KERNEL_PATCHVER:=$(KERNEL_TESTING_PATCHVER) | ||||||
| endif | endif | ||||||
|  |  | ||||||
| LINUX_VERSION-4.14 = .169 | LINUX_VERSION-4.14 = .171 | ||||||
| LINUX_VERSION-4.19 = .101 | LINUX_VERSION-4.19 = .101 | ||||||
|  |  | ||||||
| LINUX_KERNEL_HASH-4.14.169 = d88ea97993c56b1fa0b0a05061bcde476c6be4fc3bb2de8bd97a8f8ff7278249 | LINUX_KERNEL_HASH-4.14.171 = 4fe02489e4b4a187eccf0ef87df6100534c9d485e76d876b1fa247c7635332a0 | ||||||
| LINUX_KERNEL_HASH-4.19.101 = be26156abdb38ac0576a34a235ef456bb8ca67fbbe56fc6649b8d069159f8bc4 | LINUX_KERNEL_HASH-4.19.101 = be26156abdb38ac0576a34a235ef456bb8ca67fbbe56fc6649b8d069159f8bc4 | ||||||
|  |  | ||||||
| remove_uri_prefix=$(subst git://,,$(subst http://,,$(subst https://,,$(1)))) | remove_uri_prefix=$(subst git://,,$(subst http://,,$(subst https://,,$(1)))) | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| --- a/drivers/gpio/Kconfig | --- a/drivers/gpio/Kconfig | ||||||
| +++ b/drivers/gpio/Kconfig | +++ b/drivers/gpio/Kconfig | ||||||
| @@ -1299,4 +1299,12 @@ config GPIO_VIPERBOARD | @@ -1300,4 +1300,12 @@ config GPIO_VIPERBOARD | ||||||
|   |   | ||||||
|  endmenu |  endmenu | ||||||
|   |   | ||||||
|   | |||||||
| @@ -109,7 +109,7 @@ | |||||||
| +#endif | +#endif | ||||||
| --- a/drivers/gpio/Kconfig | --- a/drivers/gpio/Kconfig | ||||||
| +++ b/drivers/gpio/Kconfig | +++ b/drivers/gpio/Kconfig | ||||||
| @@ -1251,7 +1251,6 @@ menu "SPI GPIO expanders" | @@ -1252,7 +1252,6 @@ menu "SPI GPIO expanders" | ||||||
|   |   | ||||||
|  config GPIO_74X164 |  config GPIO_74X164 | ||||||
|  	tristate "74x164 serial-in/parallel-out 8-bits shift register" |  	tristate "74x164 serial-in/parallel-out 8-bits shift register" | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| --- a/drivers/gpio/Kconfig | --- a/drivers/gpio/Kconfig | ||||||
| +++ b/drivers/gpio/Kconfig | +++ b/drivers/gpio/Kconfig | ||||||
| @@ -1306,4 +1306,9 @@ config GPIO_NXP_74HC153 | @@ -1307,4 +1307,9 @@ config GPIO_NXP_74HC153 | ||||||
|  	  Platform driver for NXP 74HC153 Dual 4-input Multiplexer. This |  	  Platform driver for NXP 74HC153 Dual 4-input Multiplexer. This | ||||||
|  	  provides a GPIO interface supporting input mode only. |  	  provides a GPIO interface supporting input mode only. | ||||||
|   |   | ||||||
|   | |||||||
| @@ -831,7 +831,7 @@ | |||||||
|   * No flags defined yet. |   * No flags defined yet. | ||||||
| --- a/net/core/utils.c | --- a/net/core/utils.c | ||||||
| +++ b/net/core/utils.c | +++ b/net/core/utils.c | ||||||
| @@ -424,8 +424,14 @@ void inet_proto_csum_replace16(__sum16 * | @@ -441,8 +441,14 @@ void inet_proto_csum_replace16(__sum16 * | ||||||
|  			       bool pseudohdr) |  			       bool pseudohdr) | ||||||
|  { |  { | ||||||
|  	__be32 diff[] = { |  	__be32 diff[] = { | ||||||
|   | |||||||
| @@ -212,7 +212,7 @@ | |||||||
| +MODULE_ALIAS("platform:" DRIVER_NAME); | +MODULE_ALIAS("platform:" DRIVER_NAME); | ||||||
| --- a/drivers/watchdog/Kconfig | --- a/drivers/watchdog/Kconfig | ||||||
| +++ b/drivers/watchdog/Kconfig | +++ b/drivers/watchdog/Kconfig | ||||||
| @@ -1646,6 +1646,13 @@ config PIC32_DMT | @@ -1647,6 +1647,13 @@ config PIC32_DMT | ||||||
|  	  To compile this driver as a loadable module, choose M here. |  	  To compile this driver as a loadable module, choose M here. | ||||||
|  	  The module will be called pic32-dmt. |  	  The module will be called pic32-dmt. | ||||||
|   |   | ||||||
|   | |||||||
| @@ -811,7 +811,7 @@ | |||||||
|   * No flags defined yet. |   * No flags defined yet. | ||||||
| --- a/net/core/utils.c | --- a/net/core/utils.c | ||||||
| +++ b/net/core/utils.c | +++ b/net/core/utils.c | ||||||
| @@ -424,8 +424,14 @@ void inet_proto_csum_replace16(__sum16 * | @@ -441,8 +441,14 @@ void inet_proto_csum_replace16(__sum16 * | ||||||
|  			       bool pseudohdr) |  			       bool pseudohdr) | ||||||
|  { |  { | ||||||
|  	__be32 diff[] = { |  	__be32 diff[] = { | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ Subject: [PATCH 210/210] b44: register adm switch | |||||||
|   |   | ||||||
|  #include <linux/uaccess.h> |  #include <linux/uaccess.h> | ||||||
|  #include <asm/io.h> |  #include <asm/io.h> | ||||||
| @@ -2248,6 +2250,69 @@ static void b44_adjust_link(struct net_d | @@ -2251,6 +2253,69 @@ static void b44_adjust_link(struct net_d | ||||||
|  	} |  	} | ||||||
|  } |  } | ||||||
|   |   | ||||||
| @@ -89,7 +89,7 @@ Subject: [PATCH 210/210] b44: register adm switch | |||||||
|  static int b44_register_phy_one(struct b44 *bp) |  static int b44_register_phy_one(struct b44 *bp) | ||||||
|  { |  { | ||||||
|  	struct mii_bus *mii_bus; |  	struct mii_bus *mii_bus; | ||||||
| @@ -2283,6 +2348,9 @@ static int b44_register_phy_one(struct b | @@ -2286,6 +2351,9 @@ static int b44_register_phy_one(struct b | ||||||
|  	if (!mdiobus_is_registered_device(bp->mii_bus, bp->phy_addr) && |  	if (!mdiobus_is_registered_device(bp->mii_bus, bp->phy_addr) && | ||||||
|  	    (sprom->boardflags_lo & (B44_BOARDFLAG_ROBO | B44_BOARDFLAG_ADM))) { |  	    (sprom->boardflags_lo & (B44_BOARDFLAG_ROBO | B44_BOARDFLAG_ADM))) { | ||||||
|   |   | ||||||
| @@ -99,7 +99,7 @@ Subject: [PATCH 210/210] b44: register adm switch | |||||||
|  		dev_info(sdev->dev, |  		dev_info(sdev->dev, | ||||||
|  			 "could not find PHY at %i, use fixed one\n", |  			 "could not find PHY at %i, use fixed one\n", | ||||||
|  			 bp->phy_addr); |  			 bp->phy_addr); | ||||||
| @@ -2477,6 +2545,7 @@ static void b44_remove_one(struct ssb_de | @@ -2480,6 +2548,7 @@ static void b44_remove_one(struct ssb_de | ||||||
|  	unregister_netdev(dev); |  	unregister_netdev(dev); | ||||||
|  	if (bp->flags & B44_FLAG_EXTERNAL_PHY) |  	if (bp->flags & B44_FLAG_EXTERNAL_PHY) | ||||||
|  		b44_unregister_phy_one(bp); |  		b44_unregister_phy_one(bp); | ||||||
|   | |||||||
| @@ -43,7 +43,7 @@ | |||||||
|   |   | ||||||
|  	if (bp->flags & B44_FLAG_EXTERNAL_PHY) |  	if (bp->flags & B44_FLAG_EXTERNAL_PHY) | ||||||
|  		return 0; |  		return 0; | ||||||
| @@ -2178,6 +2203,8 @@ static int b44_get_invariants(struct b44 | @@ -2181,6 +2206,8 @@ static int b44_get_invariants(struct b44 | ||||||
|  	 * valid PHY address. */ |  	 * valid PHY address. */ | ||||||
|  	bp->phy_addr &= 0x1F; |  	bp->phy_addr &= 0x1F; | ||||||
|   |   | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ Signed-off-by: Mathias Adam <m.adam--openwrt@adamis.de> | |||||||
|  |  | ||||||
| --- a/drivers/watchdog/Kconfig | --- a/drivers/watchdog/Kconfig | ||||||
| +++ b/drivers/watchdog/Kconfig | +++ b/drivers/watchdog/Kconfig | ||||||
| @@ -1472,6 +1472,15 @@ config WDT_MTX1 | @@ -1473,6 +1473,15 @@ config WDT_MTX1 | ||||||
|  	  Hardware driver for the MTX-1 boards. This is a watchdog timer that |  	  Hardware driver for the MTX-1 boards. This is a watchdog timer that | ||||||
|  	  will reboot the machine after a 100 seconds timer expired. |  	  will reboot the machine after a 100 seconds timer expired. | ||||||
|   |   | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ Signed-off-by: Rafał Miłecki <zajec5@gmail.com> | |||||||
|  |  | ||||||
| --- a/drivers/mtd/spi-nor/spi-nor.c | --- a/drivers/mtd/spi-nor/spi-nor.c | ||||||
| +++ b/drivers/mtd/spi-nor/spi-nor.c | +++ b/drivers/mtd/spi-nor/spi-nor.c | ||||||
| @@ -1226,6 +1226,18 @@ static const struct flash_info *spi_nor_ | @@ -1230,6 +1230,18 @@ static const struct flash_info *spi_nor_ | ||||||
|  	} |  	} | ||||||
|  	dev_err(nor->dev, "unrecognized JEDEC id bytes: %02x, %02x, %02x\n", |  	dev_err(nor->dev, "unrecognized JEDEC id bytes: %02x, %02x, %02x\n", | ||||||
|  		id[0], id[1], id[2]); |  		id[0], id[1], id[2]); | ||||||
|   | |||||||
| @@ -114,7 +114,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name> | |||||||
|  config MODULES_TREE_LOOKUP |  config MODULES_TREE_LOOKUP | ||||||
| --- a/kernel/module.c | --- a/kernel/module.c | ||||||
| +++ b/kernel/module.c | +++ b/kernel/module.c | ||||||
| @@ -3022,9 +3022,11 @@ static struct module *setup_load_info(st | @@ -3024,9 +3024,11 @@ static struct module *setup_load_info(st | ||||||
|   |   | ||||||
|  static int check_modinfo(struct module *mod, struct load_info *info, int flags) |  static int check_modinfo(struct module *mod, struct load_info *info, int flags) | ||||||
|  { |  { | ||||||
| @@ -127,7 +127,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name> | |||||||
|  	if (flags & MODULE_INIT_IGNORE_VERMAGIC) |  	if (flags & MODULE_INIT_IGNORE_VERMAGIC) | ||||||
|  		modmagic = NULL; |  		modmagic = NULL; | ||||||
|   |   | ||||||
| @@ -3045,6 +3047,7 @@ static int check_modinfo(struct module * | @@ -3047,6 +3049,7 @@ static int check_modinfo(struct module * | ||||||
|  				mod->name); |  				mod->name); | ||||||
|  		add_taint_module(mod, TAINT_OOT_MODULE, LOCKDEP_STILL_OK); |  		add_taint_module(mod, TAINT_OOT_MODULE, LOCKDEP_STILL_OK); | ||||||
|  	} |  	} | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| --- a/drivers/mtd/spi-nor/spi-nor.c | --- a/drivers/mtd/spi-nor/spi-nor.c | ||||||
| +++ b/drivers/mtd/spi-nor/spi-nor.c | +++ b/drivers/mtd/spi-nor/spi-nor.c | ||||||
| @@ -1032,6 +1032,7 @@ static const struct flash_info spi_nor_i | @@ -1037,6 +1037,7 @@ static const struct flash_info spi_nor_i | ||||||
|  	{ "mx25l12805d", INFO(0xc22018, 0, 64 * 1024, 256, 0) }, |  	{ "mx25l12805d", INFO(0xc22018, 0, 64 * 1024, 256, 0) }, | ||||||
|  	{ "mx25l12855e", INFO(0xc22618, 0, 64 * 1024, 256, 0) }, |  	{ "mx25l12855e", INFO(0xc22618, 0, 64 * 1024, 256, 0) }, | ||||||
|  	{ "mx25l25635e", INFO(0xc22019, 0, 64 * 1024, 512, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) }, |  	{ "mx25l25635e", INFO(0xc22019, 0, 64 * 1024, 512, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) }, | ||||||
| @@ -8,7 +8,7 @@ | |||||||
|  	{ "mx25u25635f", INFO(0xc22539, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_4B_OPCODES) }, |  	{ "mx25u25635f", INFO(0xc22539, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_4B_OPCODES) }, | ||||||
|  	{ "mx25l25655e", INFO(0xc22619, 0, 64 * 1024, 512, 0) }, |  	{ "mx25l25655e", INFO(0xc22619, 0, 64 * 1024, 512, 0) }, | ||||||
|  	{ "mx66l51235l", INFO(0xc2201a, 0, 64 * 1024, 1024, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | SPI_NOR_4B_OPCODES) }, |  	{ "mx66l51235l", INFO(0xc2201a, 0, 64 * 1024, 1024, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | SPI_NOR_4B_OPCODES) }, | ||||||
| @@ -1205,11 +1206,12 @@ static const struct flash_info spi_nor_i | @@ -1209,11 +1210,12 @@ static const struct flash_info spi_nor_i | ||||||
|  	{ }, |  	{ }, | ||||||
|  }; |  }; | ||||||
|   |   | ||||||
| @@ -23,7 +23,7 @@ | |||||||
|   |   | ||||||
|  	tmp = nor->read_reg(nor, SPINOR_OP_RDID, id, SPI_NOR_MAX_ID_LEN); |  	tmp = nor->read_reg(nor, SPINOR_OP_RDID, id, SPI_NOR_MAX_ID_LEN); | ||||||
|  	if (tmp < 0) { |  	if (tmp < 0) { | ||||||
| @@ -1220,10 +1222,16 @@ static const struct flash_info *spi_nor_ | @@ -1224,10 +1226,16 @@ static const struct flash_info *spi_nor_ | ||||||
|  	for (tmp = 0; tmp < ARRAY_SIZE(spi_nor_ids) - 1; tmp++) { |  	for (tmp = 0; tmp < ARRAY_SIZE(spi_nor_ids) - 1; tmp++) { | ||||||
|  		info = &spi_nor_ids[tmp]; |  		info = &spi_nor_ids[tmp]; | ||||||
|  		if (info->id_len) { |  		if (info->id_len) { | ||||||
| @@ -42,7 +42,7 @@ | |||||||
|  	dev_err(nor->dev, "unrecognized JEDEC id bytes: %02x, %02x, %02x\n", |  	dev_err(nor->dev, "unrecognized JEDEC id bytes: %02x, %02x, %02x\n", | ||||||
|  		id[0], id[1], id[2]); |  		id[0], id[1], id[2]); | ||||||
|  	return ERR_PTR(-ENODEV); |  	return ERR_PTR(-ENODEV); | ||||||
| @@ -2683,7 +2691,7 @@ int spi_nor_scan(struct spi_nor *nor, co | @@ -2687,7 +2695,7 @@ int spi_nor_scan(struct spi_nor *nor, co | ||||||
|  		info = spi_nor_match_id(name); |  		info = spi_nor_match_id(name); | ||||||
|  	/* Try to auto-detect if chip name wasn't specified or not found */ |  	/* Try to auto-detect if chip name wasn't specified or not found */ | ||||||
|  	if (!info) |  	if (!info) | ||||||
| @@ -51,7 +51,7 @@ | |||||||
|  	if (IS_ERR_OR_NULL(info)) |  	if (IS_ERR_OR_NULL(info)) | ||||||
|  		return -ENOENT; |  		return -ENOENT; | ||||||
|   |   | ||||||
| @@ -2694,7 +2702,7 @@ int spi_nor_scan(struct spi_nor *nor, co | @@ -2698,7 +2706,7 @@ int spi_nor_scan(struct spi_nor *nor, co | ||||||
|  	if (name && info->id_len) { |  	if (name && info->id_len) { | ||||||
|  		const struct flash_info *jinfo; |  		const struct flash_info *jinfo; | ||||||
|   |   | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ the ubi volume created by the other. | |||||||
| --- | --- | ||||||
| --- a/drivers/mtd/spi-nor/spi-nor.c | --- a/drivers/mtd/spi-nor/spi-nor.c | ||||||
| +++ b/drivers/mtd/spi-nor/spi-nor.c | +++ b/drivers/mtd/spi-nor/spi-nor.c | ||||||
| @@ -1031,7 +1031,7 @@ static const struct flash_info spi_nor_i | @@ -1036,7 +1036,7 @@ static const struct flash_info spi_nor_i | ||||||
|  	{ "mx25u6435f",  INFO(0xc22537, 0, 64 * 1024, 128, SECT_4K) }, |  	{ "mx25u6435f",  INFO(0xc22537, 0, 64 * 1024, 128, SECT_4K) }, | ||||||
|  	{ "mx25l12805d", INFO(0xc22018, 0, 64 * 1024, 256, 0) }, |  	{ "mx25l12805d", INFO(0xc22018, 0, 64 * 1024, 256, 0) }, | ||||||
|  	{ "mx25l12855e", INFO(0xc22618, 0, 64 * 1024, 256, 0) }, |  	{ "mx25l12855e", INFO(0xc22618, 0, 64 * 1024, 256, 0) }, | ||||||
|   | |||||||
| @@ -346,7 +346,7 @@ Signed-off-by: Zhao Chenhui <chenhui.zhao@freescale.com> | |||||||
|  	return 0; |  	return 0; | ||||||
|   |   | ||||||
|  err4: |  err4: | ||||||
| @@ -1073,6 +1225,8 @@ static void dwc3_get_properties(struct d | @@ -1076,6 +1228,8 @@ static void dwc3_get_properties(struct d | ||||||
|  				&hird_threshold); |  				&hird_threshold); | ||||||
|  	dwc->usb3_lpm_capable = device_property_read_bool(dev, |  	dwc->usb3_lpm_capable = device_property_read_bool(dev, | ||||||
|  				"snps,usb3_lpm_capable"); |  				"snps,usb3_lpm_capable"); | ||||||
| @@ -355,7 +355,7 @@ Signed-off-by: Zhao Chenhui <chenhui.zhao@freescale.com> | |||||||
|   |   | ||||||
|  	dwc->disable_scramble_quirk = device_property_read_bool(dev, |  	dwc->disable_scramble_quirk = device_property_read_bool(dev, | ||||||
|  				"snps,disable_scramble_quirk"); |  				"snps,disable_scramble_quirk"); | ||||||
| @@ -1105,8 +1259,16 @@ static void dwc3_get_properties(struct d | @@ -1108,8 +1262,16 @@ static void dwc3_get_properties(struct d | ||||||
|  	dwc->dis_tx_ipgap_linecheck_quirk = device_property_read_bool(dev, |  	dwc->dis_tx_ipgap_linecheck_quirk = device_property_read_bool(dev, | ||||||
|  				"snps,dis-tx-ipgap-linecheck-quirk"); |  				"snps,dis-tx-ipgap-linecheck-quirk"); | ||||||
|   |   | ||||||
| @@ -372,7 +372,7 @@ Signed-off-by: Zhao Chenhui <chenhui.zhao@freescale.com> | |||||||
|  	device_property_read_u8(dev, "snps,tx_de_emphasis", |  	device_property_read_u8(dev, "snps,tx_de_emphasis", | ||||||
|  				&tx_de_emphasis); |  				&tx_de_emphasis); | ||||||
|  	device_property_read_string(dev, "snps,hsphy_interface", |  	device_property_read_string(dev, "snps,hsphy_interface", | ||||||
| @@ -1117,6 +1279,9 @@ static void dwc3_get_properties(struct d | @@ -1120,6 +1282,9 @@ static void dwc3_get_properties(struct d | ||||||
|  	dwc->dis_metastability_quirk = device_property_read_bool(dev, |  	dwc->dis_metastability_quirk = device_property_read_bool(dev, | ||||||
|  				"snps,dis_metastability_quirk"); |  				"snps,dis_metastability_quirk"); | ||||||
|   |   | ||||||
| @@ -382,7 +382,7 @@ Signed-off-by: Zhao Chenhui <chenhui.zhao@freescale.com> | |||||||
|  	dwc->lpm_nyet_threshold = lpm_nyet_threshold; |  	dwc->lpm_nyet_threshold = lpm_nyet_threshold; | ||||||
|  	dwc->tx_de_emphasis = tx_de_emphasis; |  	dwc->tx_de_emphasis = tx_de_emphasis; | ||||||
|   |   | ||||||
| @@ -1368,12 +1533,14 @@ static int dwc3_resume_common(struct dwc | @@ -1371,12 +1536,14 @@ static int dwc3_resume_common(struct dwc | ||||||
|   |   | ||||||
|  	switch (dwc->dr_mode) { |  	switch (dwc->dr_mode) { | ||||||
|  	case USB_DR_MODE_PERIPHERAL: |  	case USB_DR_MODE_PERIPHERAL: | ||||||
|   | |||||||
| @@ -158,7 +158,7 @@ Signed-off-by: Signed-off-by: Biwen Li <biwen.li@nxp.com> | |||||||
|  	if (kvm_is_device_pfn(pfn)) { |  	if (kvm_is_device_pfn(pfn)) { | ||||||
|  		mem_type = PAGE_S2_DEVICE; |  		mem_type = PAGE_S2_DEVICE; | ||||||
|  		flags |= KVM_S2PTE_FLAG_IS_IOMAP; |  		flags |= KVM_S2PTE_FLAG_IS_IOMAP; | ||||||
| @@ -1918,6 +1961,9 @@ int kvm_arch_prepare_memory_region(struc | @@ -1919,6 +1962,9 @@ int kvm_arch_prepare_memory_region(struc | ||||||
|  			gpa_t gpa = mem->guest_phys_addr + |  			gpa_t gpa = mem->guest_phys_addr + | ||||||
|  				    (vm_start - mem->userspace_addr); |  				    (vm_start - mem->userspace_addr); | ||||||
|  			phys_addr_t pa; |  			phys_addr_t pa; | ||||||
| @@ -168,7 +168,7 @@ Signed-off-by: Signed-off-by: Biwen Li <biwen.li@nxp.com> | |||||||
|   |   | ||||||
|  			pa = (phys_addr_t)vma->vm_pgoff << PAGE_SHIFT; |  			pa = (phys_addr_t)vma->vm_pgoff << PAGE_SHIFT; | ||||||
|  			pa += vm_start - vma->vm_start; |  			pa += vm_start - vma->vm_start; | ||||||
| @@ -1928,9 +1974,13 @@ int kvm_arch_prepare_memory_region(struc | @@ -1929,9 +1975,13 @@ int kvm_arch_prepare_memory_region(struc | ||||||
|  				goto out; |  				goto out; | ||||||
|  			} |  			} | ||||||
|   |   | ||||||
|   | |||||||
| @@ -1512,7 +1512,7 @@ Signed-off-by: Yogesh Gaur <yogeshnarayan.gaur@nxp.com> | |||||||
|  	case SNOR_MFR_MICRON: |  	case SNOR_MFR_MICRON: | ||||||
|  		/* Some Micron need WREN command; all will accept it */ |  		/* Some Micron need WREN command; all will accept it */ | ||||||
|  		need_wren = true; |  		need_wren = true; | ||||||
| @@ -1039,7 +1040,7 @@ static const struct flash_info spi_nor_i | @@ -1044,7 +1045,7 @@ static const struct flash_info spi_nor_i | ||||||
|  	{ "mx66l1g45g",  INFO(0xc2201b, 0, 64 * 1024, 2048, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) }, |  	{ "mx66l1g45g",  INFO(0xc2201b, 0, 64 * 1024, 2048, SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) }, | ||||||
|  	{ "mx66l1g55g",  INFO(0xc2261b, 0, 64 * 1024, 2048, SPI_NOR_QUAD_READ) }, |  	{ "mx66l1g55g",  INFO(0xc2261b, 0, 64 * 1024, 2048, SPI_NOR_QUAD_READ) }, | ||||||
|   |   | ||||||
| @@ -1521,7 +1521,7 @@ Signed-off-by: Yogesh Gaur <yogeshnarayan.gaur@nxp.com> | |||||||
|  	{ "n25q016a",	 INFO(0x20bb15, 0, 64 * 1024,   32, SECT_4K | SPI_NOR_QUAD_READ) }, |  	{ "n25q016a",	 INFO(0x20bb15, 0, 64 * 1024,   32, SECT_4K | SPI_NOR_QUAD_READ) }, | ||||||
|  	{ "n25q032",	 INFO(0x20ba16, 0, 64 * 1024,   64, SPI_NOR_QUAD_READ) }, |  	{ "n25q032",	 INFO(0x20ba16, 0, 64 * 1024,   64, SPI_NOR_QUAD_READ) }, | ||||||
|  	{ "n25q032a",	 INFO(0x20bb16, 0, 64 * 1024,   64, SPI_NOR_QUAD_READ) }, |  	{ "n25q032a",	 INFO(0x20bb16, 0, 64 * 1024,   64, SPI_NOR_QUAD_READ) }, | ||||||
| @@ -1054,6 +1055,12 @@ static const struct flash_info spi_nor_i | @@ -1059,6 +1060,12 @@ static const struct flash_info spi_nor_i | ||||||
|  	{ "n25q00",      INFO(0x20ba21, 0, 64 * 1024, 2048, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ | NO_CHIP_ERASE) }, |  	{ "n25q00",      INFO(0x20ba21, 0, 64 * 1024, 2048, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ | NO_CHIP_ERASE) }, | ||||||
|  	{ "n25q00a",     INFO(0x20bb21, 0, 64 * 1024, 2048, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ | NO_CHIP_ERASE) }, |  	{ "n25q00a",     INFO(0x20bb21, 0, 64 * 1024, 2048, SECT_4K | USE_FSR | SPI_NOR_QUAD_READ | NO_CHIP_ERASE) }, | ||||||
|   |   | ||||||
| @@ -1534,7 +1534,7 @@ Signed-off-by: Yogesh Gaur <yogeshnarayan.gaur@nxp.com> | |||||||
|  	/* PMC */ |  	/* PMC */ | ||||||
|  	{ "pm25lv512",   INFO(0,        0, 32 * 1024,    2, SECT_4K_PMC) }, |  	{ "pm25lv512",   INFO(0,        0, 32 * 1024,    2, SECT_4K_PMC) }, | ||||||
|  	{ "pm25lv010",   INFO(0,        0, 32 * 1024,    4, SECT_4K_PMC) }, |  	{ "pm25lv010",   INFO(0,        0, 32 * 1024,    4, SECT_4K_PMC) }, | ||||||
| @@ -2435,6 +2442,7 @@ static int spi_nor_init_params(struct sp | @@ -2439,6 +2446,7 @@ static int spi_nor_init_params(struct sp | ||||||
|  			params->quad_enable = macronix_quad_enable; |  			params->quad_enable = macronix_quad_enable; | ||||||
|  			break; |  			break; | ||||||
|   |   | ||||||
| @@ -1542,7 +1542,7 @@ Signed-off-by: Yogesh Gaur <yogeshnarayan.gaur@nxp.com> | |||||||
|  		case SNOR_MFR_MICRON: |  		case SNOR_MFR_MICRON: | ||||||
|  			break; |  			break; | ||||||
|   |   | ||||||
| @@ -2753,7 +2761,8 @@ int spi_nor_scan(struct spi_nor *nor, co | @@ -2757,7 +2765,8 @@ int spi_nor_scan(struct spi_nor *nor, co | ||||||
|  	mtd->_read = spi_nor_read; |  	mtd->_read = spi_nor_read; | ||||||
|   |   | ||||||
|  	/* NOR protection support for STmicro/Micron chips and similar */ |  	/* NOR protection support for STmicro/Micron chips and similar */ | ||||||
|   | |||||||
| @@ -5618,7 +5618,7 @@ Signed-off-by: Yangbo Lu <yangbo.lu@nxp.com> | |||||||
|  static void quirk_no_pm_reset(struct pci_dev *dev) |  static void quirk_no_pm_reset(struct pci_dev *dev) | ||||||
|  { |  { | ||||||
|  	/* |  	/* | ||||||
| @@ -4884,3 +4891,11 @@ static void quirk_no_ats(struct pci_dev | @@ -4918,3 +4925,11 @@ static void quirk_no_ats(struct pci_dev | ||||||
|  DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_ATI, 0x98e4, quirk_no_ats); |  DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_ATI, 0x98e4, quirk_no_ats); | ||||||
|  DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_ATI, 0x6900, quirk_no_ats); |  DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_ATI, 0x6900, quirk_no_ats); | ||||||
|  #endif /* CONFIG_PCI_ATS */ |  #endif /* CONFIG_PCI_ATS */ | ||||||
|   | |||||||
| @@ -124,7 +124,7 @@ Signed-off-by: Biwen Li <biwen.li@nxp.com> | |||||||
|  L:	keyrings@vger.kernel.org |  L:	keyrings@vger.kernel.org | ||||||
| --- a/drivers/tee/optee/Kconfig | --- a/drivers/tee/optee/Kconfig | ||||||
| +++ b/drivers/tee/optee/Kconfig | +++ b/drivers/tee/optee/Kconfig | ||||||
| @@ -5,3 +5,11 @@ config OPTEE | @@ -6,3 +6,11 @@ config OPTEE | ||||||
|  	help |  	help | ||||||
|  	  This implements the OP-TEE Trusted Execution Environment (TEE) |  	  This implements the OP-TEE Trusted Execution Environment (TEE) | ||||||
|  	  driver. |  	  driver. | ||||||
|   | |||||||
| @@ -718,7 +718,7 @@ Signed-off-by: Yogesh Gaur <yogeshnarayan.gaur@nxp.com> | |||||||
|   |   | ||||||
| --- a/drivers/mtd/spi-nor/spi-nor.c | --- a/drivers/mtd/spi-nor/spi-nor.c | ||||||
| +++ b/drivers/mtd/spi-nor/spi-nor.c | +++ b/drivers/mtd/spi-nor/spi-nor.c | ||||||
| @@ -1154,6 +1154,11 @@ static const struct flash_info spi_nor_i | @@ -1159,6 +1159,11 @@ static const struct flash_info spi_nor_i | ||||||
|  	{ "w25x40", INFO(0xef3013, 0, 64 * 1024,  8,  SECT_4K) }, |  	{ "w25x40", INFO(0xef3013, 0, 64 * 1024,  8,  SECT_4K) }, | ||||||
|  	{ "w25x80", INFO(0xef3014, 0, 64 * 1024,  16, SECT_4K) }, |  	{ "w25x80", INFO(0xef3014, 0, 64 * 1024,  16, SECT_4K) }, | ||||||
|  	{ "w25x16", INFO(0xef3015, 0, 64 * 1024,  32, SECT_4K) }, |  	{ "w25x16", INFO(0xef3015, 0, 64 * 1024,  32, SECT_4K) }, | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| --- a/arch/powerpc/Kconfig | --- a/arch/powerpc/Kconfig | ||||||
| +++ b/arch/powerpc/Kconfig | +++ b/arch/powerpc/Kconfig | ||||||
| @@ -836,6 +836,14 @@ config CMDLINE_FORCE | @@ -837,6 +837,14 @@ config CMDLINE_FORCE | ||||||
|  	  This is useful if you cannot or don't want to change the |  	  This is useful if you cannot or don't want to change the | ||||||
|  	  command-line options your boot loader passes to the kernel. |  	  command-line options your boot loader passes to the kernel. | ||||||
|   |   | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ Signed-off-by: Abhimanyu Vishwakarma <Abhimanyu.Vishwakarma@imgtec.com> | |||||||
|  |  | ||||||
| --- a/drivers/mtd/spi-nor/spi-nor.c | --- a/drivers/mtd/spi-nor/spi-nor.c | ||||||
| +++ b/drivers/mtd/spi-nor/spi-nor.c | +++ b/drivers/mtd/spi-nor/spi-nor.c | ||||||
| @@ -2667,6 +2667,7 @@ int spi_nor_scan(struct spi_nor *nor, co | @@ -2671,6 +2671,7 @@ int spi_nor_scan(struct spi_nor *nor, co | ||||||
|  	struct device *dev = nor->dev; |  	struct device *dev = nor->dev; | ||||||
|  	struct mtd_info *mtd = &nor->mtd; |  	struct mtd_info *mtd = &nor->mtd; | ||||||
|  	struct device_node *np = spi_nor_get_flash_node(nor); |  	struct device_node *np = spi_nor_get_flash_node(nor); | ||||||
| @@ -18,7 +18,7 @@ Signed-off-by: Abhimanyu Vishwakarma <Abhimanyu.Vishwakarma@imgtec.com> | |||||||
|  	int ret; |  	int ret; | ||||||
|  	int i; |  	int i; | ||||||
|   |   | ||||||
| @@ -2742,7 +2743,12 @@ int spi_nor_scan(struct spi_nor *nor, co | @@ -2746,7 +2747,12 @@ int spi_nor_scan(struct spi_nor *nor, co | ||||||
|  		spi_nor_wait_till_ready(nor); |  		spi_nor_wait_till_ready(nor); | ||||||
|  	} |  	} | ||||||
|   |   | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ Signed-off-by: John Crispin <blogic@openwrt.org> | |||||||
|  |  | ||||||
| --- a/drivers/media/usb/uvc/uvc_driver.c | --- a/drivers/media/usb/uvc/uvc_driver.c | ||||||
| +++ b/drivers/media/usb/uvc/uvc_driver.c | +++ b/drivers/media/usb/uvc/uvc_driver.c | ||||||
| @@ -2737,6 +2737,18 @@ static const struct usb_device_id uvc_id | @@ -2749,6 +2749,18 @@ static const struct usb_device_id uvc_id | ||||||
|  	  .bInterfaceSubClass	= 1, |  	  .bInterfaceSubClass	= 1, | ||||||
|  	  .bInterfaceProtocol	= 0, |  	  .bInterfaceProtocol	= 0, | ||||||
|  	  .driver_info		= UVC_QUIRK_FORCE_Y8 }, |  	  .driver_info		= UVC_QUIRK_FORCE_Y8 }, | ||||||
|   | |||||||
| @@ -116,7 +116,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name> | |||||||
|   |   | ||||||
|  	spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_LOCK); |  	spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_LOCK); | ||||||
|  	return ret; |  	return ret; | ||||||
| @@ -1177,7 +1229,7 @@ static const struct flash_info spi_nor_i | @@ -1182,7 +1234,7 @@ static const struct flash_info spi_nor_i | ||||||
|  	{ "w25q80", INFO(0xef5014, 0, 64 * 1024,  16, SECT_4K) }, |  	{ "w25q80", INFO(0xef5014, 0, 64 * 1024,  16, SECT_4K) }, | ||||||
|  	{ "w25q80bl", INFO(0xef4014, 0, 64 * 1024,  16, SECT_4K) }, |  	{ "w25q80bl", INFO(0xef4014, 0, 64 * 1024,  16, SECT_4K) }, | ||||||
|  	{ "w25q128", INFO(0xef4018, 0, 64 * 1024, 256, SECT_4K) }, |  	{ "w25q128", INFO(0xef4018, 0, 64 * 1024, 256, SECT_4K) }, | ||||||
| @@ -125,7 +125,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name> | |||||||
|  	{ "w25m512jv", INFO(0xef7119, 0, 64 * 1024, 1024, |  	{ "w25m512jv", INFO(0xef7119, 0, 64 * 1024, 1024, | ||||||
|  			SECT_4K | SPI_NOR_QUAD_READ | SPI_NOR_DUAL_READ) }, |  			SECT_4K | SPI_NOR_QUAD_READ | SPI_NOR_DUAL_READ) }, | ||||||
|   |   | ||||||
| @@ -1241,6 +1293,9 @@ static int spi_nor_read(struct mtd_info | @@ -1245,6 +1297,9 @@ static int spi_nor_read(struct mtd_info | ||||||
|  	if (ret) |  	if (ret) | ||||||
|  		return ret; |  		return ret; | ||||||
|   |   | ||||||
| @@ -135,7 +135,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name> | |||||||
|  	while (len) { |  	while (len) { | ||||||
|  		loff_t addr = from; |  		loff_t addr = from; | ||||||
|   |   | ||||||
| @@ -1265,6 +1320,18 @@ static int spi_nor_read(struct mtd_info | @@ -1269,6 +1324,18 @@ static int spi_nor_read(struct mtd_info | ||||||
|  	ret = 0; |  	ret = 0; | ||||||
|   |   | ||||||
|  read_err: |  read_err: | ||||||
| @@ -154,7 +154,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name> | |||||||
|  	spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_READ); |  	spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_READ); | ||||||
|  	return ret; |  	return ret; | ||||||
|  } |  } | ||||||
| @@ -1366,6 +1433,10 @@ static int spi_nor_write(struct mtd_info | @@ -1370,6 +1437,10 @@ static int spi_nor_write(struct mtd_info | ||||||
|  	if (ret) |  	if (ret) | ||||||
|  		return ret; |  		return ret; | ||||||
|   |   | ||||||
| @@ -165,7 +165,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name> | |||||||
|  	for (i = 0; i < len; ) { |  	for (i = 0; i < len; ) { | ||||||
|  		ssize_t written; |  		ssize_t written; | ||||||
|  		loff_t addr = to + i; |  		loff_t addr = to + i; | ||||||
| @@ -1406,6 +1477,7 @@ static int spi_nor_write(struct mtd_info | @@ -1410,6 +1481,7 @@ static int spi_nor_write(struct mtd_info | ||||||
|  	} |  	} | ||||||
|   |   | ||||||
|  write_err: |  write_err: | ||||||
| @@ -173,7 +173,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name> | |||||||
|  	spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_WRITE); |  	spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_WRITE); | ||||||
|  	return ret; |  	return ret; | ||||||
|  } |  } | ||||||
| @@ -2822,8 +2894,10 @@ int spi_nor_scan(struct spi_nor *nor, co | @@ -2826,8 +2898,10 @@ int spi_nor_scan(struct spi_nor *nor, co | ||||||
|  	} else if (mtd->size > 0x1000000) { |  	} else if (mtd->size > 0x1000000) { | ||||||
|  		/* enable 4-byte addressing if the device exceeds 16MiB */ |  		/* enable 4-byte addressing if the device exceeds 16MiB */ | ||||||
|  		nor->addr_width = 4; |  		nor->addr_width = 4; | ||||||
|   | |||||||
| @@ -33,7 +33,7 @@ | |||||||
|  /* |  /* | ||||||
|   * Write status register 1 byte |   * Write status register 1 byte | ||||||
|   * Returns negative if error occurred. |   * Returns negative if error occurred. | ||||||
| @@ -2894,9 +2903,16 @@ int spi_nor_scan(struct spi_nor *nor, co | @@ -2898,9 +2907,16 @@ int spi_nor_scan(struct spi_nor *nor, co | ||||||
|  	} else if (mtd->size > 0x1000000) { |  	} else if (mtd->size > 0x1000000) { | ||||||
|  		/* enable 4-byte addressing if the device exceeds 16MiB */ |  		/* enable 4-byte addressing if the device exceeds 16MiB */ | ||||||
|  		nor->addr_width = 4; |  		nor->addr_width = 4; | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| --- a/drivers/mtd/spi-nor/spi-nor.c | --- a/drivers/mtd/spi-nor/spi-nor.c | ||||||
| +++ b/drivers/mtd/spi-nor/spi-nor.c | +++ b/drivers/mtd/spi-nor/spi-nor.c | ||||||
| @@ -1061,6 +1061,11 @@ static const struct flash_info spi_nor_i | @@ -1066,6 +1066,11 @@ static const struct flash_info spi_nor_i | ||||||
|  			SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | |  			SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | | ||||||
|  			SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB) |  			SPI_NOR_HAS_LOCK | SPI_NOR_HAS_TB) | ||||||
|  	}, |  	}, | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ For reference see: | |||||||
|  |  | ||||||
| --- a/drivers/mtd/spi-nor/spi-nor.c | --- a/drivers/mtd/spi-nor/spi-nor.c | ||||||
| +++ b/drivers/mtd/spi-nor/spi-nor.c | +++ b/drivers/mtd/spi-nor/spi-nor.c | ||||||
| @@ -1098,6 +1098,7 @@ static const struct flash_info spi_nor_i | @@ -1103,6 +1103,7 @@ static const struct flash_info spi_nor_i | ||||||
|  	{ "mx25l12805d", INFO(0xc22018, 0, 64 * 1024, 256, 0) }, |  	{ "mx25l12805d", INFO(0xc22018, 0, 64 * 1024, 256, 0) }, | ||||||
|  	{ "mx25l12855e", INFO(0xc22618, 0, 64 * 1024, 256, 0) }, |  	{ "mx25l12855e", INFO(0xc22618, 0, 64 * 1024, 256, 0) }, | ||||||
|  	{ "mx25l25635e", INFO(0xc22019, 0, 64 * 1024, 512, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) }, |  	{ "mx25l25635e", INFO(0xc22019, 0, 64 * 1024, 512, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ) }, | ||||||
| @@ -18,7 +18,7 @@ For reference see: | |||||||
|  	{ "mx25u25635f", INFO(0xc22539, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_4B_OPCODES) }, |  	{ "mx25u25635f", INFO(0xc22539, 0, 64 * 1024, 512, SECT_4K | SPI_NOR_4B_OPCODES) }, | ||||||
|  	{ "mx25l25655e", INFO(0xc22619, 0, 64 * 1024, 512, 0) }, |  	{ "mx25l25655e", INFO(0xc22619, 0, 64 * 1024, 512, 0) }, | ||||||
|  	{ "mx66l51235l", INFO(0xc2201a, 0, 64 * 1024, 1024, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | SPI_NOR_4B_OPCODES) }, |  	{ "mx66l51235l", INFO(0xc2201a, 0, 64 * 1024, 1024, SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ | SPI_NOR_4B_OPCODES) }, | ||||||
| @@ -1271,11 +1272,12 @@ static const struct flash_info spi_nor_i | @@ -1275,11 +1276,12 @@ static const struct flash_info spi_nor_i | ||||||
|  	{ }, |  	{ }, | ||||||
|  }; |  }; | ||||||
|   |   | ||||||
| @@ -33,7 +33,7 @@ For reference see: | |||||||
|   |   | ||||||
|  	tmp = nor->read_reg(nor, SPINOR_OP_RDID, id, SPI_NOR_MAX_ID_LEN); |  	tmp = nor->read_reg(nor, SPINOR_OP_RDID, id, SPI_NOR_MAX_ID_LEN); | ||||||
|  	if (tmp < 0) { |  	if (tmp < 0) { | ||||||
| @@ -1286,10 +1288,16 @@ static const struct flash_info *spi_nor_ | @@ -1290,10 +1292,16 @@ static const struct flash_info *spi_nor_ | ||||||
|  	for (tmp = 0; tmp < ARRAY_SIZE(spi_nor_ids) - 1; tmp++) { |  	for (tmp = 0; tmp < ARRAY_SIZE(spi_nor_ids) - 1; tmp++) { | ||||||
|  		info = &spi_nor_ids[tmp]; |  		info = &spi_nor_ids[tmp]; | ||||||
|  		if (info->id_len) { |  		if (info->id_len) { | ||||||
| @@ -52,7 +52,7 @@ For reference see: | |||||||
|  	dev_err(nor->dev, "unrecognized JEDEC id bytes: %02x, %02x, %02x\n", |  	dev_err(nor->dev, "unrecognized JEDEC id bytes: %02x, %02x, %02x\n", | ||||||
|  		id[0], id[1], id[2]); |  		id[0], id[1], id[2]); | ||||||
|  	return ERR_PTR(-ENODEV); |  	return ERR_PTR(-ENODEV); | ||||||
| @@ -2769,7 +2777,7 @@ int spi_nor_scan(struct spi_nor *nor, co | @@ -2773,7 +2781,7 @@ int spi_nor_scan(struct spi_nor *nor, co | ||||||
|  		info = spi_nor_match_id(name); |  		info = spi_nor_match_id(name); | ||||||
|  	/* Try to auto-detect if chip name wasn't specified or not found */ |  	/* Try to auto-detect if chip name wasn't specified or not found */ | ||||||
|  	if (!info) |  	if (!info) | ||||||
| @@ -61,7 +61,7 @@ For reference see: | |||||||
|  	if (IS_ERR_OR_NULL(info)) |  	if (IS_ERR_OR_NULL(info)) | ||||||
|  		return -ENOENT; |  		return -ENOENT; | ||||||
|   |   | ||||||
| @@ -2780,7 +2788,7 @@ int spi_nor_scan(struct spi_nor *nor, co | @@ -2784,7 +2792,7 @@ int spi_nor_scan(struct spi_nor *nor, co | ||||||
|  	if (name && info->id_len) { |  	if (name && info->id_len) { | ||||||
|  		const struct flash_info *jinfo; |  		const struct flash_info *jinfo; | ||||||
|   |   | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Koen Vandeputte
					Koen Vandeputte