Johnny Hughes
2018-04-10 7ddead2b0c6f5530842929bd82428176bcdd33db
Manual CentOS Debranding and config changes
4 files added
3 files modified
1010 ■■■■■ changed files
SOURCES/8001-Update-xgene-smmu-iommu-acpi-hwmon-misc.patch 894 ●●●●● patch | view | raw | blame | history
SOURCES/8002-efifb-arm-arm64-validate-fb-BAR-instead-of-claiming-it.patch 77 ●●●●● patch | view | raw | blame | history
SOURCES/centos-kpatch.x509 patch | view | raw | blame | history
SOURCES/centos-ldup.x509 patch | view | raw | blame | history
SOURCES/kernel-alt-4.14.0-aarch64.config 4 ●●●● patch | view | raw | blame | history
SOURCES/x509.genkey 6 ●●●● patch | view | raw | blame | history
SPECS/kernel-alt.spec 29 ●●●● patch | view | raw | blame | history
SOURCES/8001-Update-xgene-smmu-iommu-acpi-hwmon-misc.patch
New file
@@ -0,0 +1,894 @@
From d21d9c34519285b89858cd1056a470be5c083f0d Mon Sep 17 00:00:00 2001
From: Khuong Dinh <kdinh@apm.com>
Date: Fri, 13 Oct 2017 16:07:46 -0600
Subject: [PATCH 01/10] Bug 62016: BACKPORT: iommu: enable bypass
 transaction caching for ARM SMMU 500
The ARM SMMU identity mapping performance was poor compared with the
DMA mode. It was found that enable caching would restore the performance
back to normal. The S2CRB_TLBEN bit in the ACR register would allow for
caching of the stream to context register bypass transaction information.
This patch is backported from: https://patchwork.kernel.org/patch/10000707/
and is in opensource review progress.
Change-Id: Iea8230870f7b39d1006c2e515707a0e612e69cc9
Signed-off-by: Feng Kan <fkan@apm.com>
Signed-off-by: Khuong Dinh <kdinh@apm.com>
---
 drivers/iommu/arm-smmu.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/drivers/iommu/arm-smmu.c b/drivers/iommu/arm-smmu.c
index 86690eb..7abea92 100644
--- a/drivers/iommu/arm-smmu.c
+++ b/drivers/iommu/arm-smmu.c
@@ -255,6 +255,7 @@ enum arm_smmu_s2cr_privcfg {
 #define ARM_MMU500_ACTLR_CPRE        (1 << 1)
 #define ARM_MMU500_ACR_CACHE_LOCK    (1 << 26)
+#define ARM_MMU500_ACR_S2CRB_TLBEN    (1 << 10)
 #define ARM_MMU500_ACR_SMTNMB_TLBEN    (1 << 8)
 #define CB_PAR_F            (1 << 0)
@@ -1713,7 +1714,7 @@ static void arm_smmu_device_reset(struct arm_smmu_device *smmu)
          * Allow unmatched Stream IDs to allocate bypass
          * TLB entries for reduced latency.
          */
-        reg |= ARM_MMU500_ACR_SMTNMB_TLBEN;
+        reg |= ARM_MMU500_ACR_SMTNMB_TLBEN | ARM_MMU500_ACR_S2CRB_TLBEN;
         writel_relaxed(reg, gr0_base + ARM_SMMU_GR0_sACR);
     }
--
2.7.4
From 752386ad06d60dedb61986e5ce1ec5a166f0da8b Mon Sep 17 00:00:00 2001
From: Rameshwar Prasad Sahu <rsahu@apm.com>
Date: Thu, 9 Nov 2017 06:14:16 -0500
Subject: [PATCH 02/10] BACKPORT: ata: fixes kernel crash while
 tracing ata_eh_link_autopsy event
When tracing ata link error event, the kernel crashes when the disk is
removed due to NULL pointer access by trace_ata_eh_link_autopsy API.
This occurs as the dev is NULL when the disk disappeared. This patch
fixes this crash by calling trace_ata_eh_link_autopsy only if "dev"
is not NULL.
Patch reference:
https://git.kernel.org/pub/scm/linux/kernel/git/tj/libata.git/commit/?h=for-4.15&id=f1601113ddc0339a745e702f4fb1ca37d4875e65
This patch is required to support user space RAS for X-Gene hardware v3
for PCIe and SATA protocols.
Change-Id: I63747a4017f95cfb2976253ef1f0422991073887
Signed-off-by: Rameshwar Prasad Sahu <rsahu@apm.com>
---
 drivers/ata/libata-eh.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/ata/libata-eh.c b/drivers/ata/libata-eh.c
index ef68232..9307556 100644
--- a/drivers/ata/libata-eh.c
+++ b/drivers/ata/libata-eh.c
@@ -2330,8 +2330,8 @@ static void ata_eh_link_autopsy(struct ata_link *link)
         if (dev->flags & ATA_DFLAG_DUBIOUS_XFER)
             eflags |= ATA_EFLAG_DUBIOUS_XFER;
         ehc->i.action |= ata_eh_speed_down(dev, eflags, all_err_mask);
+        trace_ata_eh_link_autopsy(dev, ehc->i.action, all_err_mask);
     }
-    trace_ata_eh_link_autopsy(dev, ehc->i.action, all_err_mask);
     DPRINTK("EXIT\n");
 }
--
2.7.4
From 137568a663f2197807b1ac524564c6c5293f8f7d Mon Sep 17 00:00:00 2001
From: Toan Le <toanle@apm.com>
Date: Thu, 30 Nov 2017 15:10:23 -0800
Subject: [PATCH 03/10] BACKPORT: iommu/iova: Fix underflow bug in
 __alloc_and_insert_iova_range
Normally, calling alloc_iova() using an iova_domain with insufficient
pfns remaining between start_pfn and dma_limit will fail and return a
NULL pointer. Unexpectedly, if such a "full" iova_domain contains an
iova with pfn_lo == 0, the alloc_iova() call will instead succeed and
return an iova containing invalid pfns.
This is caused by an underflow bug in __alloc_and_insert_iova_range()
that occurs after walking the "full" iova tree when the search ends
at the iova with pfn_lo == 0 and limit_pfn is then adjusted to be just
below that (-1). This (now huge) limit_pfn gives the impression that a
vast amount of space is available between it and start_pfn and thus
a new iova is allocated with the invalid pfn_hi value, 0xFFF.... .
To rememdy this, a check is introduced to ensure that adjustments to
limit_pfn will not underflow.
This issue has been observed in the wild, and is easily reproduced with
the following sample code.
    struct iova_domain *iovad = kzalloc(sizeof(*iovad), GFP_KERNEL);
    struct iova *rsvd_iova, *good_iova, *bad_iova;
    unsigned long limit_pfn = 3;
    unsigned long start_pfn = 1;
    unsigned long va_size = 2;
    init_iova_domain(iovad, SZ_4K, start_pfn, limit_pfn);
    rsvd_iova = reserve_iova(iovad, 0, 0);
    good_iova = alloc_iova(iovad, va_size, limit_pfn, true);
    bad_iova = alloc_iova(iovad, va_size, limit_pfn, true);
Prior to the patch, this yielded:
    *rsvd_iova == {0, 0}   /* Expected */
    *good_iova == {2, 3}   /* Expected */
    *bad_iova  == {-2, -1} /* Oh no... */
After the patch, bad_iova is NULL as expected since inadequate
space remains between limit_pfn and start_pfn after allocating
good_iova.
( Original patch https://patchwork.kernel.org/patch/9668743/ )
APM context description:
When we have either "ConnectX-5 Ex" or "XL710" populated to the system,
many Virtual Function contexts are created at probe time of host driver.
The iova underflow happens (which is described within patch description)
which produces invalid pfns. As the result, Tx traffic is observed to
hang, or system crashes with trace of iommu_dma_unmap().
Change-Id: Ia19d7a3df4c986f53532e30a3db030b304a5461c
Signed-off-by: Nate Watterson <nwatters@codeaurora.org>
Signed-off-by: Joerg Roedel <jroedel@suse.de>
[fkan to propose integration and do initial upstream testing]
Signed-off-by: Feng Kan <fkan@apm.com>
[toanle to fix build issue]
Signed-off-by: Toan Le <toanle@apm.com>
---
 drivers/iommu/iova.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/iommu/iova.c b/drivers/iommu/iova.c
index b7268a1..f6533e0 100644
--- a/drivers/iommu/iova.c
+++ b/drivers/iommu/iova.c
@@ -138,7 +138,7 @@ static int __alloc_and_insert_iova_range(struct iova_domain *iovad,
                 break;    /* found a free slot */
         }
 adjust_limit_pfn:
-        limit_pfn = curr_iova->pfn_lo - 1;
+        limit_pfn = curr_iova->pfn_lo ? (curr_iova->pfn_lo - 1) : 0;
 move_left:
         prev = curr;
         curr = rb_prev(curr);
--
2.7.4
From 9b752f7a6e0b722fb090afd4dbddb45c24c6a9e2 Mon Sep 17 00:00:00 2001
From: Tin Huynh <tnhuynh@apm.com>
Date: Mon, 23 Oct 2017 10:53:35 +0700
Subject: [PATCH 04/10] BACKPORT: ACPI / scan: Apply default enumeration to
 devices with ACPI drivers
The current code in acpi_bus_attach() is inconsistent with respect
to device objects with ACPI drivers bound to them, as it allows
ACPI drivers to bind to device objects with existing "physical"
device companions, but it doesn't allow "physical" device objects
to be created for ACPI device objects with ACPI drivers bound to
them.  Thus, in some cases, the outcome depends on the ordering
of events which is confusing at best.
For this reason, modify acpi_bus_attach() to call
acpi_default_enumeration() for device objects with the
pnp.type.platform_id flag set regardless of whether or not
any ACPI drivers are bound to them.
This patch is backported from:
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/?h=next-20171018&id=f5beabfe61794d9a9d9549d387cda2bffd81e504
Without the patch, ACPI devices declared in DSDT would not be enumerated,
hence, both I2C MUX/LED on Merlin and SSIF of OPEN IPMI on Ospey do not work.
Change-Id: I790d367175d429ddbce205ba2b89447f19618968
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Reviewed-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Reviewed-by: Joey Lee <jlee@suse.com>
Signed-off-by: Tin Huynh <tnhuynh@apm.com>
---
 drivers/acpi/scan.c | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/drivers/acpi/scan.c b/drivers/acpi/scan.c
index 68cf49b..1204f5f 100644
--- a/drivers/acpi/scan.c
+++ b/drivers/acpi/scan.c
@@ -1946,10 +1946,10 @@ static void acpi_bus_attach(struct acpi_device *device)
     if (ret < 0)
         return;
-    if (ret > 0 || !device->pnp.type.platform_id)
-        acpi_device_set_enumerated(device);
-    else
+    if (device->pnp.type.platform_id)
         acpi_default_enumeration(device);
+    else
+        acpi_device_set_enumerated(device);
  ok:
     list_for_each_entry(child, &device->children, node)
--
2.7.4
From cad717698fc617fcc1f48c7d1f9a3bc5832ce73a Mon Sep 17 00:00:00 2001
From: Tin Huynh <tnhuynh@apm.com>
Date: Mon, 23 Oct 2017 15:41:34 +0700
Subject: [PATCH 05/10] BACKPORT: ACPI / scan: Fix enumeration for special SPI
 and I2C devices
Commit f406270bf73d ("ACPI / scan: Set the visited flag for all
enumerated devices") caused that two group of special SPI or I2C
devices do not enumerate. SPI and I2C devices are expected to be
enumerated by the SPI and I2C subsystems but change caused that
acpi_bus_attach() marks those devices with acpi_device_set_enumerated().
First group of devices are matched using Device Tree compatible property
with special _HID "PRP0001". Those devices have matched scan handler,
acpi_scan_attach_handler() retuns 1 and acpi_bus_attach() marks them
with acpi_device_set_enumerated().
Second group of devices without valid _HID such as "LNXVIDEO" have
device->pnp.type.platform_id set to zero and change again marks them
with acpi_device_set_enumerated().
Fix this by flagging the SPI and I2C devices during struct acpi_device
object initialization time and let the code in acpi_bus_attach() to go
through the device_attach() and acpi_default_enumeration() path for all
SPI and I2C devices.
This patch is backported from:
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=e4330d8bf669139a983255d1801733b64c2ae841
Without the patch, ACPI devices declared in DSDT would not be enumerated,
hence, both I2C MUX/LED on Merlin and SSIF of OPEN IPMI on Osprey do not work.
The patch should be applied after
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/?h=next-20171018&id=f5beabfe61794d9a9d9549d387cda2bffd81e504
because of easily keeping track of history of Open Source
Change-Id: I8a6dd8df8ac6318d16b90ed2d1677370efde686c
Fixes: f406270bf73d (ACPI / scan: Set the visited flag for all enumerated devices)
Signed-off-by: Jarkko Nikula <jarkko.nikula@linux.intel.com>
Acked-by: Mika Westerberg <mika.westerberg@linux.intel.com>
Cc: 4.11+ <stable@vger.kernel.org> # 4.11+
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: Tin Huynh <tnhuynh@apm.com>
---
 drivers/acpi/scan.c     | 67 +++++++++++++++++++++++++++----------------------
 include/acpi/acpi_bus.h |  3 ++-
 2 files changed, 39 insertions(+), 31 deletions(-)
diff --git a/drivers/acpi/scan.c b/drivers/acpi/scan.c
index 1204f5f..96cbd09 100644
--- a/drivers/acpi/scan.c
+++ b/drivers/acpi/scan.c
@@ -1513,6 +1513,37 @@ static void acpi_init_coherency(struct acpi_device *adev)
     adev->flags.coherent_dma = cca;
 }
+static int acpi_check_spi_i2c_slave(struct acpi_resource *ares, void *data)
+{
+    bool *is_spi_i2c_slave_p = data;
+
+    if (ares->type != ACPI_RESOURCE_TYPE_SERIAL_BUS)
+        return 1;
+
+    /*
+     * devices that are connected to UART still need to be enumerated to
+     * platform bus
+     */
+    if (ares->data.common_serial_bus.type != ACPI_RESOURCE_SERIAL_TYPE_UART)
+        *is_spi_i2c_slave_p = true;
+
+     /* no need to do more checking */
+    return -1;
+}
+
+static bool acpi_is_spi_i2c_slave(struct acpi_device *device)
+{
+    struct list_head resource_list;
+    bool is_spi_i2c_slave = false;
+
+    INIT_LIST_HEAD(&resource_list);
+    acpi_dev_get_resources(device, &resource_list, acpi_check_spi_i2c_slave,
+                   &is_spi_i2c_slave);
+    acpi_dev_free_resource_list(&resource_list);
+
+    return is_spi_i2c_slave;
+}
+
 void acpi_init_device_object(struct acpi_device *device, acpi_handle handle,
                  int type, unsigned long long sta)
 {
@@ -1528,6 +1559,7 @@ void acpi_init_device_object(struct acpi_device *device, acpi_handle handle,
     acpi_bus_get_flags(device);
     device->flags.match_driver = false;
     device->flags.initialized = true;
+    device->flags.spi_i2c_slave = acpi_is_spi_i2c_slave(device);
     acpi_device_clear_enumerated(device);
     device_initialize(&device->dev);
     dev_set_uevent_suppress(&device->dev, true);
@@ -1812,38 +1844,13 @@ static acpi_status acpi_bus_check_add(acpi_handle handle, u32 lvl_not_used,
     return AE_OK;
 }
-static int acpi_check_spi_i2c_slave(struct acpi_resource *ares, void *data)
-{
-    bool *is_spi_i2c_slave_p = data;
-
-    if (ares->type != ACPI_RESOURCE_TYPE_SERIAL_BUS)
-        return 1;
-
-    /*
-     * devices that are connected to UART still need to be enumerated to
-     * platform bus
-     */
-    if (ares->data.common_serial_bus.type != ACPI_RESOURCE_SERIAL_TYPE_UART)
-        *is_spi_i2c_slave_p = true;
-
-     /* no need to do more checking */
-    return -1;
-}
-
 static void acpi_default_enumeration(struct acpi_device *device)
 {
-    struct list_head resource_list;
-    bool is_spi_i2c_slave = false;
-
     /*
      * Do not enumerate SPI/I2C slaves as they will be enumerated by their
      * respective parents.
      */
-    INIT_LIST_HEAD(&resource_list);
-    acpi_dev_get_resources(device, &resource_list, acpi_check_spi_i2c_slave,
-                   &is_spi_i2c_slave);
-    acpi_dev_free_resource_list(&resource_list);
-    if (!is_spi_i2c_slave) {
+    if (!device->flags.spi_i2c_slave) {
         acpi_create_platform_device(device, NULL);
         acpi_device_set_enumerated(device);
     } else {
@@ -1937,7 +1944,7 @@ static void acpi_bus_attach(struct acpi_device *device)
         return;
     device->flags.match_driver = true;
-    if (ret > 0) {
+    if (ret > 0 && !device->flags.spi_i2c_slave) {
         acpi_device_set_enumerated(device);
         goto ok;
     }
@@ -1946,10 +1953,10 @@ static void acpi_bus_attach(struct acpi_device *device)
     if (ret < 0)
         return;
-    if (device->pnp.type.platform_id)
-        acpi_default_enumeration(device);
-    else
+    if (!device->pnp.type.platform_id && !device->flags.spi_i2c_slave)
         acpi_device_set_enumerated(device);
+    else
+        acpi_default_enumeration(device);
  ok:
     list_for_each_entry(child, &device->children, node)
diff --git a/include/acpi/acpi_bus.h b/include/acpi/acpi_bus.h
index 2b82493..1472250 100644
--- a/include/acpi/acpi_bus.h
+++ b/include/acpi/acpi_bus.h
@@ -209,7 +209,8 @@ struct acpi_device_flags {
     u32 of_compatible_ok:1;
     u32 coherent_dma:1;
     u32 cca_seen:1;
-    u32 reserved:20;
+    u32 spi_i2c_slave:1;
+    u32 reserved:19;
 };
 /* File System */
--
2.7.4
From 4a71fbb59680880ac0eec624fea1f67ef69e0b62 Mon Sep 17 00:00:00 2001
From: Hoan Tran <hotran@apm.com>
Date: Mon, 30 Oct 2017 15:24:16 -0700
Subject: [PATCH 06/10] BACKPORT: i2c: xgene-slimpro: Support v2
This patch supports xgene-slimpro-i2c v2 which uses the non-cachable memory
as the PCC shared memory.
This patch is backported from:
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/?id=da24b8240fe6afdeef388a2ef1da662b25675a5a
We backported this for future firmware when it switches PPC mailbox
to OCM. At this point, this isn't being used.
Change-Id: I38d3825454e307d02c98f2f6583099e708c47b7c
Signed-off-by: Hoan Tran <hotran@apm.com>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
---
 drivers/i2c/busses/i2c-xgene-slimpro.c | 30 ++++++++++++++++++++++++++----
 1 file changed, 26 insertions(+), 4 deletions(-)
diff --git a/drivers/i2c/busses/i2c-xgene-slimpro.c b/drivers/i2c/busses/i2c-xgene-slimpro.c
index 8e5c8f2..cbb4da4 100644
--- a/drivers/i2c/busses/i2c-xgene-slimpro.c
+++ b/drivers/i2c/busses/i2c-xgene-slimpro.c
@@ -128,6 +128,11 @@ struct slimpro_i2c_dev {
 #define to_slimpro_i2c_dev(cl)    \
         container_of(cl, struct slimpro_i2c_dev, mbox_client)
+enum slimpro_i2c_version {
+    XGENE_SLIMPRO_I2C_V1 = 0,
+    XGENE_SLIMPRO_I2C_V2 = 1,
+};
+
 /*
  * This function tests and clears a bitmask then returns its old value
  */
@@ -475,6 +480,15 @@ static int xgene_slimpro_i2c_probe(struct platform_device *pdev)
         }
     } else {
         struct acpi_pcct_hw_reduced *cppc_ss;
+        const struct acpi_device_id *acpi_id;
+        int version = XGENE_SLIMPRO_I2C_V1;
+
+        acpi_id = acpi_match_device(pdev->dev.driver->acpi_match_table,
+                        &pdev->dev);
+        if (!acpi_id)
+            return -EINVAL;
+
+        version = (int)acpi_id->driver_data;
         if (device_property_read_u32(&pdev->dev, "pcc-channel",
                          &ctx->mbox_idx))
@@ -513,9 +527,16 @@ static int xgene_slimpro_i2c_probe(struct platform_device *pdev)
          */
         ctx->comm_base_addr = cppc_ss->base_address;
         if (ctx->comm_base_addr) {
-            ctx->pcc_comm_addr = memremap(ctx->comm_base_addr,
-                              cppc_ss->length,
-                              MEMREMAP_WB);
+            if (version == XGENE_SLIMPRO_I2C_V2)
+                ctx->pcc_comm_addr = memremap(
+                            ctx->comm_base_addr,
+                            cppc_ss->length,
+                            MEMREMAP_WT);
+            else
+                ctx->pcc_comm_addr = memremap(
+                            ctx->comm_base_addr,
+                            cppc_ss->length,
+                            MEMREMAP_WB);
         } else {
             dev_err(&pdev->dev, "Failed to get PCC comm region\n");
             rc = -ENOENT;
@@ -580,7 +601,8 @@ MODULE_DEVICE_TABLE(of, xgene_slimpro_i2c_dt_ids);
 #ifdef CONFIG_ACPI
 static const struct acpi_device_id xgene_slimpro_i2c_acpi_ids[] = {
-    {"APMC0D40", 0},
+    {"APMC0D40", XGENE_SLIMPRO_I2C_V1},
+    {"APMC0D8B", XGENE_SLIMPRO_I2C_V2},
     {}
 };
 MODULE_DEVICE_TABLE(acpi, xgene_slimpro_i2c_acpi_ids);
--
2.7.4
From 74290528f88b2b86c7659f235021c62c6146bce1 Mon Sep 17 00:00:00 2001
From: hotran <hotran@apm.com>
Date: Tue, 17 Oct 2017 11:28:34 -0700
Subject: [PATCH 07/10] hwmon: (xgene) Support hwmon v2
This patch supports xgene-hwmon v2 which uses the non-cachable memory
as the PCC shared memory.
Signed-off-by: Hoan Tran <hotran@apm.com>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: root <root@localhost.localdomain>
---
 drivers/hwmon/xgene-hwmon.c | 40 +++++++++++++++++++++++++++++++---------
 1 file changed, 31 insertions(+), 9 deletions(-)
diff --git a/drivers/hwmon/xgene-hwmon.c b/drivers/hwmon/xgene-hwmon.c
index 9c0dbb8..b4e3f11 100644
--- a/drivers/hwmon/xgene-hwmon.c
+++ b/drivers/hwmon/xgene-hwmon.c
@@ -91,6 +91,11 @@
 #define to_xgene_hwmon_dev(cl)        \
     container_of(cl, struct xgene_hwmon_dev, mbox_client)
+enum xgene_hwmon_version {
+    XGENE_HWMON_V1 = 0,
+    XGENE_HWMON_V2 = 1,
+};
+
 struct slimpro_resp_msg {
     u32 msg;
     u32 param1;
@@ -609,6 +614,15 @@ static void xgene_hwmon_tx_done(struct mbox_client *cl, void *msg, int ret)
     }
 }
+#ifdef CONFIG_ACPI
+static const struct acpi_device_id xgene_hwmon_acpi_match[] = {
+    {"APMC0D29", XGENE_HWMON_V1},
+    {"APMC0D8A", XGENE_HWMON_V2},
+    {},
+};
+MODULE_DEVICE_TABLE(acpi, xgene_hwmon_acpi_match);
+#endif
+
 static int xgene_hwmon_probe(struct platform_device *pdev)
 {
     struct xgene_hwmon_dev *ctx;
@@ -650,6 +664,16 @@ static int xgene_hwmon_probe(struct platform_device *pdev)
         }
     } else {
         struct acpi_pcct_hw_reduced *cppc_ss;
+        int version = XGENE_HWMON_V1;
+#ifdef CONFIG_ACPI
+        const struct acpi_device_id *acpi_id;
+
+        acpi_id = acpi_match_device(xgene_hwmon_acpi_match, &pdev->dev);
+        if (!acpi_id)
+            return -EINVAL;
+
+        version = (int)acpi_id->driver_data;
+#endif
         if (device_property_read_u32(&pdev->dev, "pcc-channel",
                          &ctx->mbox_idx)) {
@@ -690,7 +714,13 @@ static int xgene_hwmon_probe(struct platform_device *pdev)
          */
         ctx->comm_base_addr = cppc_ss->base_address;
         if (ctx->comm_base_addr) {
-            ctx->pcc_comm_addr = memremap(ctx->comm_base_addr,
+            if (version == XGENE_HWMON_V2)
+                ctx->pcc_comm_addr = (void __force *)ioremap(
+                            ctx->comm_base_addr,
+                            cppc_ss->length);
+            else
+                ctx->pcc_comm_addr = memremap(
+                            ctx->comm_base_addr,
                             cppc_ss->length,
                             MEMREMAP_WB);
         } else {
@@ -758,14 +788,6 @@ static int xgene_hwmon_remove(struct platform_device *pdev)
     return 0;
 }
-#ifdef CONFIG_ACPI
-static const struct acpi_device_id xgene_hwmon_acpi_match[] = {
-    {"APMC0D29", 0},
-    {},
-};
-MODULE_DEVICE_TABLE(acpi, xgene_hwmon_acpi_match);
-#endif
-
 static const struct of_device_id xgene_hwmon_of_match[] = {
     {.compatible = "apm,xgene-slimpro-hwmon"},
     {}
--
2.7.4
From d76b990d0b4a264ece8abd7651a43394e9f7ae5b Mon Sep 17 00:00:00 2001
From: Aleksey Makarov <aleksey.makarov@linaro.org>
Date: Wed, 15 Mar 2017 13:28:50 +0300
Subject: [PATCH 08/10] printk: fix name/type/scope of preferred_console var
The variable preferred_console is used only inside register_console()
and its semantics is boolean.  It is negative when no console has been
made preferred.
Make it static bool and rename to has_preferred.
Renaming was suggested by Peter Hurley
Link: http://lkml.kernel.org/r/20170315102854.1763-2-aleksey.makarov@linaro.org
Cc: Sudeep Holla <sudeep.holla@arm.com>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: Peter Hurley <peter@hurleysoftware.com>
Cc: Jiri Slaby <jslaby@suse.com>
Cc: Robin Murphy <robin.murphy@arm.com>
Cc: "Nair, Jayachandran" <Jayachandran.Nair@cavium.com>
Cc: linux-serial@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Signed-off-by: Aleksey Makarov <aleksey.makarov@linaro.org>
Reviewed-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
Reviewed-by: Sergey Senozhatsky <sergey.senozhatsky@gmail.com>
Signed-off-by: Petr Mladek <pmladek@suse.com>
Signed-off-by: root <root@localhost.localdomain>
---
 kernel/printk/printk.c | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c
index 2984fb0..80bc1b7 100644
--- a/kernel/printk/printk.c
+++ b/kernel/printk/printk.c
@@ -271,7 +271,6 @@ static struct console *exclusive_console;
 static struct console_cmdline console_cmdline[MAX_CMDLINECONSOLES];
 static int selected_console = -1;
-static int preferred_console = -1;
 int console_set_on_cmdline;
 EXPORT_SYMBOL(console_set_on_cmdline);
@@ -2409,6 +2408,7 @@ void register_console(struct console *newcon)
     unsigned long flags;
     struct console *bcon = NULL;
     struct console_cmdline *c;
+    static bool has_preferred;
     if (console_drivers)
         for_each_console(bcon)
@@ -2435,15 +2435,15 @@ void register_console(struct console *newcon)
     if (console_drivers && console_drivers->flags & CON_BOOT)
         bcon = console_drivers;
-    if (preferred_console < 0 || bcon || !console_drivers)
-        preferred_console = selected_console;
+    if (!has_preferred || bcon || !console_drivers)
+        has_preferred = selected_console >= 0;
     /*
      *    See if we want to use this console driver. If we
      *    didn't select a console we take the first one
      *    that registers here.
      */
-    if (preferred_console < 0) {
+    if (!has_preferred) {
         if (newcon->index < 0)
             newcon->index = 0;
         if (newcon->setup == NULL ||
@@ -2451,7 +2451,7 @@ void register_console(struct console *newcon)
             newcon->flags |= CON_ENABLED;
             if (newcon->device) {
                 newcon->flags |= CON_CONSDEV;
-                preferred_console = 0;
+                has_preferred = true;
             }
         }
     }
@@ -2486,7 +2486,7 @@ void register_console(struct console *newcon)
         newcon->flags |= CON_ENABLED;
         if (i == selected_console) {
             newcon->flags |= CON_CONSDEV;
-            preferred_console = selected_console;
+            has_preferred = true;
         }
         break;
     }
--
2.7.4
From 9e084a1e78086b2c6cf489542fe8553e3311e92f Mon Sep 17 00:00:00 2001
From: Aleksey Makarov <aleksey.makarov@linaro.org>
Date: Wed, 15 Mar 2017 13:28:51 +0300
Subject: [PATCH 09/10] printk: rename selected_console -> preferred_console
The variable selected_console is set in __add_preferred_console()
to point to the last console parameter that was added to the
console_cmdline array.
Rename it to preferred_console so that the name reflects the usage.
Petr Mladek:
"[..] the selected_console/preferred_console
value is used to keep the console first in the console_drivers list.
IMHO, the main effect is that each line will first appear on this
console, see call_console_drivers(). But the message will still
appear also on all other enabled consoles. From this point,
the name "preferred" sounds better to me. More consoles
are selected (enabled) and only one is preferred (first)."
Link: http://lkml.kernel.org/r/20170315102854.1763-3-aleksey.makarov@linaro.org
Cc: Sudeep Holla <sudeep.holla@arm.com>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: Jiri Slaby <jslaby@suse.com>
Cc: Robin Murphy <robin.murphy@arm.com>
Cc: "Nair, Jayachandran" <Jayachandran.Nair@cavium.com>
Cc: linux-serial@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Signed-off-by: Aleksey Makarov <aleksey.makarov@linaro.org>
Suggested-by: Peter Hurley <peter@hurleysoftware.com>
Acked-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
Reviewed-by: Sergey Senozhatsky <sergey.senozhatsky@gmail.com>
Signed-off-by: Petr Mladek <pmladek@suse.com>
Signed-off-by: root <root@localhost.localdomain>
---
 kernel/printk/printk.c | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c
index 80bc1b7..fd752f0 100644
--- a/kernel/printk/printk.c
+++ b/kernel/printk/printk.c
@@ -270,7 +270,7 @@ static struct console *exclusive_console;
 static struct console_cmdline console_cmdline[MAX_CMDLINECONSOLES];
-static int selected_console = -1;
+static int preferred_console = -1;
 int console_set_on_cmdline;
 EXPORT_SYMBOL(console_set_on_cmdline);
@@ -1910,14 +1910,14 @@ static int __add_preferred_console(char *name, int idx, char *options,
          i++, c++) {
         if (strcmp(c->name, name) == 0 && c->index == idx) {
             if (!brl_options)
-                selected_console = i;
+                preferred_console = i;
             return 0;
         }
     }
     if (i == MAX_CMDLINECONSOLES)
         return -E2BIG;
     if (!brl_options)
-        selected_console = i;
+        preferred_console = i;
     strlcpy(c->name, name, sizeof(c->name));
     c->options = options;
     braille_set_options(c, brl_options);
@@ -2436,7 +2436,7 @@ void register_console(struct console *newcon)
         bcon = console_drivers;
     if (!has_preferred || bcon || !console_drivers)
-        has_preferred = selected_console >= 0;
+        has_preferred = preferred_console >= 0;
     /*
      *    See if we want to use this console driver. If we
@@ -2484,7 +2484,7 @@ void register_console(struct console *newcon)
         }
         newcon->flags |= CON_ENABLED;
-        if (i == selected_console) {
+        if (i == preferred_console) {
             newcon->flags |= CON_CONSDEV;
             has_preferred = true;
         }
--
2.7.4
From d14a1d2003bc8e15c3724d9679bc49e7c5ff778e Mon Sep 17 00:00:00 2001
From: Aleksey Makarov <aleksey.makarov@linaro.org>
Date: Wed, 5 Apr 2017 23:20:00 +0300
Subject: [PATCH 10/10] printk: fix double printing with earlycon
If a console was specified by ACPI SPCR table _and_ command line
parameters like "console=ttyAMA0" _and_ "earlycon" were specified,
then log messages appear twice.
The root cause is that the code traverses the list of specified
consoles (the `console_cmdline` array) and stops at the first match.
But it may happen that the same console is referred by the elements
of this array twice:
    pl011,mmio,0x87e024000000,115200 -- from SPCR
    ttyAMA0 -- from command line
but in this case `preferred_console` points to the second entry and
the flag CON_CONSDEV is not set, so bootconsole is not deregistered.
To fix that, introduce an invariant "The last non-braille console
is always the preferred one" on the entries of the console_cmdline
array.  Then traverse it in reverse order to be sure that if
the console is preferred then it will be the first matching entry.
Introduce variable console_cmdline_cnt that keeps the number
of elements of the console_cmdline array (Petr Mladek).  It helps
to get rid of the loop that searches for the end of this array.
Link: http://lkml.kernel.org/r/20170405202006.18234-1-aleksey.makarov@linaro.org
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: Peter Hurley <peter@hurleysoftware.com>
Cc: Jiri Slaby <jslaby@suse.com>
Cc: Robin Murphy <robin.murphy@arm.com>
Cc: "Nair, Jayachandran" <Jayachandran.Nair@cavium.com>
Cc: linux-serial@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Signed-off-by: Aleksey Makarov <aleksey.makarov@linaro.org>
Reported-by: Sudeep Holla <sudeep.holla@arm.com>
Acked-by: Sergey Senozhatsky <sergey.senozhatsky@gmail.com>
Signed-off-by: Petr Mladek <pmladek@suse.com>
Signed-off-by: root <root@localhost.localdomain>
---
 kernel/printk/printk.c | 46 ++++++++++++++++++++++++++++++++++++----------
 1 file changed, 36 insertions(+), 10 deletions(-)
diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c
index fd752f0..9ecf567 100644
--- a/kernel/printk/printk.c
+++ b/kernel/printk/printk.c
@@ -269,6 +269,7 @@ static struct console *exclusive_console;
 #define MAX_CMDLINECONSOLES 8
 static struct console_cmdline console_cmdline[MAX_CMDLINECONSOLES];
+static int console_cmdline_cnt;
 static int preferred_console = -1;
 int console_set_on_cmdline;
@@ -1905,12 +1906,25 @@ static int __add_preferred_console(char *name, int idx, char *options,
      *    See if this tty is not yet registered, and
      *    if we have a slot free.
      */
-    for (i = 0, c = console_cmdline;
-         i < MAX_CMDLINECONSOLES && c->name[0];
-         i++, c++) {
+    for (i = 0, c = console_cmdline; i < console_cmdline_cnt; i++, c++) {
         if (strcmp(c->name, name) == 0 && c->index == idx) {
-            if (!brl_options)
-                preferred_console = i;
+            if (brl_options)
+                return 0;
+
+            /*
+             * Maintain an invariant that will help to find if
+             * the matching console is preferred, see
+             * register_console():
+             *
+             * The last non-braille console is always
+             * the preferred one.
+             */
+            if (i != console_cmdline_cnt - 1)
+                swap(console_cmdline[i],
+                     console_cmdline[console_cmdline_cnt - 1]);
+
+            preferred_console = console_cmdline_cnt - 1;
+
             return 0;
         }
     }
@@ -1923,6 +1937,7 @@ static int __add_preferred_console(char *name, int idx, char *options,
     braille_set_options(c, brl_options);
     c->index = idx;
+    console_cmdline_cnt++;
     return 0;
 }
 /*
@@ -2457,12 +2472,23 @@ void register_console(struct console *newcon)
     }
     /*
-     *    See if this console matches one we selected on
-     *    the command line.
+     * See if this console matches one we selected on the command line.
+     *
+     * There may be several entries in the console_cmdline array matching
+     * with the same console, one with newcon->match(), another by
+     * name/index:
+     *
+     *    pl011,mmio,0x87e024000000,115200 -- added from SPCR
+     *    ttyAMA0 -- added from command line
+     *
+     * Traverse the console_cmdline array in reverse order to be
+     * sure that if this console is preferred then it will be the first
+     * matching entry.  We use the invariant that is maintained in
+     * __add_preferred_console().
      */
-    for (i = 0, c = console_cmdline;
-         i < MAX_CMDLINECONSOLES && c->name[0];
-         i++, c++) {
+    for (i = console_cmdline_cnt - 1; i >= 0; i--) {
+        c = console_cmdline + i;
+
         if (!newcon->match ||
             newcon->match(newcon, c->name, c->index, c->options) != 0) {
             /* default matching */
--
2.7.4
SOURCES/8002-efifb-arm-arm64-validate-fb-BAR-instead-of-claiming-it.patch
New file
@@ -0,0 +1,77 @@
From bda44e856b33d2fbb17a618a87bddafaeb97dabd Mon Sep 17 00:00:00 2001
From: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Date: Fri, 26 Jun 2015 16:55:30 -0400
Subject: [PATCH] efifb: arm/arm64: validate fb BAR instead of claiming
 it
Claiming the BAR that matches the framebuffer base address in a PCI
header fixup quirk only works as expected when the PCI device is on
bus 0. If not, it will produce the following error:
pci 0000:01:01.0: can't claim BAR 0 [mem 0x10000000-0x10ffffff pref]:
                                                 no compatible bridge window
pci 0000:01:01.0: BAR 0: failed to claim resource for efifb!
Since claiming the entire path up to the root is non-trivial at this
point, and also undesirable given that we have no way of making sure
that the existing configuration is sound, let's not claim anything at
all, and simply record the resource so we can check that it did not
move when the EFI fb driver is probed.
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: knguyen <knguyen@amcc.com>
---
 drivers/video/fbdev/efifb.c | 23 +++++++++++++++++------
 1 file changed, 17 insertions(+), 6 deletions(-)
diff --git a/drivers/video/fbdev/efifb.c b/drivers/video/fbdev/efifb.c
index b827a81..21d635e 100644
--- a/drivers/video/fbdev/efifb.c
+++ b/drivers/video/fbdev/efifb.c
@@ -146,6 +146,8 @@ ATTRIBUTE_GROUPS(efifb);
 static bool pci_dev_disabled;    /* FB base matches BAR of a disabled device */
+static struct resource *pci_dev_bar_resource;
+
 static int efifb_probe(struct platform_device *dev)
 {
     struct fb_info *info;
@@ -179,6 +181,20 @@ static int efifb_probe(struct platform_device *dev)
     }
     printk(KERN_INFO "efifb: probing for efifb\n");
+    if (pci_dev_bar_resource) {
+        u64 base = screen_info.lfb_base;
+        u64 size = screen_info.lfb_size;
+
+        if (screen_info.capabilities & VIDEO_CAPABILITY_64BIT_BASE)
+            base |= (u64)screen_info.ext_lfb_base << 32;
+
+        if (pci_dev_bar_resource->start > base ||
+            pci_dev_bar_resource->end < base + size - 1) {
+            pr_err("efifb: PCI BAR has moved, disabling ...\n");
+            return -ENODEV;
+        }
+    }
+
     /* just assume they're all unset if any are */
     if (!screen_info.blue_size) {
         screen_info.blue_size = 8;
@@ -383,12 +399,7 @@ static void claim_efifb_bar(struct pci_dev *dev, int idx)
         return;
     }
-    if (pci_claim_resource(dev, idx)) {
-        pci_dev_disabled = true;
-        dev_err(&dev->dev,
-            "BAR %d: failed to claim resource for efifb!\n", idx);
-        return;
-    }
+    pci_dev_bar_resource = dev->resource + idx;
     dev_info(&dev->dev, "BAR %d: assigned to efifb\n", idx);
 }
--
2.7.4
SOURCES/centos-kpatch.x509
Binary files differ
SOURCES/centos-ldup.x509
Binary files differ
SOURCES/kernel-alt-4.14.0-aarch64.config
@@ -726,10 +726,10 @@
CONFIG_CPU_FREQ_GOV_ATTR_SET=y
CONFIG_CPU_FREQ_GOV_COMMON=y
CONFIG_CPU_FREQ_STAT=y
# CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE is not set
CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE=y
# CONFIG_CPU_FREQ_DEFAULT_GOV_POWERSAVE is not set
# CONFIG_CPU_FREQ_DEFAULT_GOV_USERSPACE is not set
CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND=y
# CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND is not set
# CONFIG_CPU_FREQ_DEFAULT_GOV_CONSERVATIVE is not set
# CONFIG_CPU_FREQ_DEFAULT_GOV_SCHEDUTIL is not set
CONFIG_CPU_FREQ_GOV_PERFORMANCE=y
SOURCES/x509.genkey
@@ -5,9 +5,9 @@
x509_extensions = myexts
[ req_distinguished_name ]
O = Red Hat
CN = Red Hat Enterprise Linux kernel signing key
emailAddress = secalert@redhat.com
O = CentOS
CN = CentOS Linux kernel signing key
emailAddress = security@centos.org
[ myexts ]
basicConstraints=critical,CA:FALSE
SPECS/kernel-alt.spec
@@ -318,6 +318,7 @@
BuildRequires: openssl openssl-devel
BuildRequires: hmaccalc
BuildRequires: python-devel, newt-devel, perl(ExtUtils::Embed)
BuildRequires: git
%ifarch x86_64
BuildRequires: pesign >= 0.109-4
%endif
@@ -360,12 +361,12 @@
Source14: secureboot.cer
%define pesign_name redhatsecureboot301
%else
Source13: redhatsecurebootca2.cer
Source14: redhatsecureboot003.cer
Source13: securebootca.cer
Source14: secureboot.cer
%define pesign_name redhatsecureboot003
%endif
Source15: rheldup3.x509
Source16: rhelkpatch1.x509
Source15: centos-ldup.x509
Source16: centos-kpatch.x509
Source18: check-kabi
@@ -397,6 +398,9 @@
# empty final patch to facilitate testing of kernel patches
Patch999999: linux-kernel-test.patch
Patch8001: 8001-Update-xgene-smmu-iommu-acpi-hwmon-misc.patch
Patch8002: 8002-efifb-arm-arm64-validate-fb-BAR-instead-of-claiming-it.patch
BuildRoot: %{_tmppath}/%{src_pkg_name}-%{KVRA}-root
@@ -717,6 +721,19 @@
ApplyOptionalPatch linux-kernel-test.patch
# Any further pre-build tree manipulations happen here.
if [ ! -d .git ]; then
  git init
  git config user.email "noreply@centos.org"
  git config user.name "AltArch Kernel"
  git config gc.auto 0
  git add .
  git commit -a -q -m "baseline"
fi
#Altarch patches
git am %{PATCH8001}
git am %{PATCH8002}
chmod +x scripts/checkpatch.pl
@@ -1570,6 +1587,10 @@
%kernel_variant_files %{with_kdump} kdump
%changelog
* Tue Apr 10 2018 Johnny Hughes <johnny@centos.org> [4.14.0-49.el7a]
- Rolled in CentOS certificates and signed modules with a CentOS certificate.
- Add Patches 8001 and 8002
* Wed Mar 14 2018 Herton R. Krzesinski <herton@redhat.com> [4.14.0-49.el7a]
- [netdrv] tg3: prevent scheduling while atomic splat (Jonathan Toppins) [1555032]
- [powerpc] KVM: PPC: Book3S HV: Fix guest time accounting with VIRT_CPU_ACCOUNTING_GEN (Laurent Vivier) [1541614]