chengshan / rpms / kernel

Forked from rpms/kernel 2 years ago
Clone
1caf23
From 15ba2cfbba429fae30b2556cd7d97b5e92d4e656 Mon Sep 17 00:00:00 2001
1caf23
From: Marcus Sundberg <marcus.sundberg@aptilo.com>
1caf23
Date: Mon, 8 Feb 2016 15:16:03 +0100
1caf23
Subject: [PATCH] i40e: Do not cast directly from pointer to u64.
1caf23
1caf23
Causes warnings on 32 bit systems.
1caf23
---
1caf23
 drivers/net/ethernet/intel/i40evf/i40e_common.c | 12 ++++++++----
1caf23
 1 file changed, 8 insertions(+), 4 deletions(-)
1caf23
1caf23
diff --git a/drivers/net/ethernet/intel/i40evf/i40e_common.c b/drivers/net/ethernet/intel/i40evf/i40e_common.c
1caf23
index 1950db1..376aab2 100644
1caf23
--- a/drivers/net/ethernet/intel/i40evf/i40e_common.c
1caf23
+++ b/drivers/net/ethernet/intel/i40evf/i40e_common.c
1caf23
@@ -442,8 +442,10 @@ static i40e_status i40e_aq_get_set_rss_lut(struct i40e_hw *hw,
1caf23
 					I40E_AQC_SET_RSS_LUT_TABLE_TYPE_SHIFT) &
1caf23
 					I40E_AQC_SET_RSS_LUT_TABLE_TYPE_MASK));
1caf23
 
1caf23
-	cmd_resp->addr_high = cpu_to_le32(high_16_bits((u64)lut));
1caf23
-	cmd_resp->addr_low = cpu_to_le32(lower_32_bits((u64)lut));
1caf23
+	cmd_resp->addr_high = cpu_to_le32(
1caf23
+		high_16_bits((u64)(unsigned long)lut));
1caf23
+	cmd_resp->addr_low = cpu_to_le32(
1caf23
+		lower_32_bits((u64)(unsigned long)lut));
1caf23
 
1caf23
 	status = i40evf_asq_send_command(hw, &desc, lut, lut_size, NULL);
1caf23
 
1caf23
@@ -519,8 +521,10 @@ static i40e_status i40e_aq_get_set_rss_key(struct i40e_hw *hw,
1caf23
 					  I40E_AQC_SET_RSS_KEY_VSI_ID_SHIFT) &
1caf23
 					  I40E_AQC_SET_RSS_KEY_VSI_ID_MASK));
1caf23
 	cmd_resp->vsi_id |= cpu_to_le16((u16)I40E_AQC_SET_RSS_KEY_VSI_VALID);
1caf23
-	cmd_resp->addr_high = cpu_to_le32(high_16_bits((u64)key));
1caf23
-	cmd_resp->addr_low = cpu_to_le32(lower_32_bits((u64)key));
1caf23
+	cmd_resp->addr_high = cpu_to_le32(
1caf23
+		high_16_bits((u64)(unsigned long)key));
1caf23
+	cmd_resp->addr_low = cpu_to_le32(
1caf23
+		lower_32_bits((u64)(unsigned long)key));
1caf23
 
1caf23
 	status = i40evf_asq_send_command(hw, &desc, key, key_size, NULL);
1caf23
 
1caf23
-- 
1caf23
1.8.3.1
1caf23
1caf23
From f11d529aa8ebd81218d8a0a2a8c04c4f41f3718f Mon Sep 17 00:00:00 2001
1caf23
From: Marcus Sundberg <marcus.sundberg@aptilo.com>
1caf23
Date: Mon, 8 Feb 2016 18:34:39 +0100
1caf23
Subject: [PATCH] iw_cxgb4: 32b platform fix
1caf23
1caf23
Casting pci_resource_start() return value directly to void * causes
1caf23
a warning.
1caf23
---
1caf23
 drivers/infiniband/hw/cxgb4/device.c | 2 +-
1caf23
 1 file changed, 1 insertion(+), 1 deletion(-)
1caf23
1caf23
diff --git a/drivers/infiniband/hw/cxgb4/device.c b/drivers/infiniband/hw/cxgb4/device.c
1caf23
index 11d55c9..94c2391 100644
1caf23
--- a/drivers/infiniband/hw/cxgb4/device.c
1caf23
+++ b/drivers/infiniband/hw/cxgb4/device.c
1caf23
@@ -830,7 +830,7 @@ static int c4iw_rdev_open(struct c4iw_rdev *rdev)
1caf23
 	PDBG("udb len 0x%x udb base %p db_reg %p gts_reg %p qpshift %lu "
1caf23
 	     "qpmask 0x%x cqshift %lu cqmask 0x%x\n",
1caf23
 	     (unsigned)pci_resource_len(rdev->lldi.pdev, 2),
1caf23
-	     (void *)pci_resource_start(rdev->lldi.pdev, 2),
1caf23
+	     (void *)(unsigned long)pci_resource_start(rdev->lldi.pdev, 2),
1caf23
 	     rdev->lldi.db_reg,
1caf23
 	     rdev->lldi.gts_reg,
1caf23
 	     rdev->qpshift, rdev->qpmask,
1caf23
-- 
1caf23
1.8.3.1
1caf23
1caf23
From 39f3f2d7be077d4a067d95ea2b3f02e51f7a05f3 Mon Sep 17 00:00:00 2001
1caf23
From: Marcus Sundberg <marcus.sundberg@aptilo.com>
1caf23
Date: Mon, 8 Feb 2016 18:18:10 +0100
1caf23
Subject: [PATCH] nvme: fix pointer cast warnings on 32 bit
1caf23
1caf23
---
1caf23
 drivers/block/nvme-core.c | 9 +++++----
1caf23
 1 file changed, 5 insertions(+), 4 deletions(-)
1caf23
1caf23
diff --git a/drivers/block/nvme-core.c b/drivers/block/nvme-core.c
1caf23
index 711d96a..eafb721 100644
1caf23
--- a/drivers/block/nvme-core.c
1caf23
+++ b/drivers/block/nvme-core.c
1caf23
@@ -1693,8 +1693,9 @@ static int nvme_submit_io(struct nvme_ns *ns, struct nvme_user_io __user *uio)
1caf23
 			goto unmap;
1caf23
 		}
1caf23
 		if (write) {
1caf23
-			if (copy_from_user(meta, (void __user *)io.metadata,
1caf23
-					   meta_len)) {
1caf23
+			if (copy_from_user(meta,
1caf23
+					(void __user *)(uintptr_t)io.metadata,
1caf23
+					meta_len)) {
1caf23
 				status = -EFAULT;
1caf23
 				goto unmap;
1caf23
 			}
1caf23
@@ -1722,8 +1723,8 @@ static int nvme_submit_io(struct nvme_ns *ns, struct nvme_user_io __user *uio)
1caf23
 
1caf23
 	if (meta) {
1caf23
 		if (status == NVME_SC_SUCCESS && !write) {
1caf23
-			if (copy_to_user((void __user *)io.metadata, meta,
1caf23
-					 meta_len))
1caf23
+			if (copy_to_user((void __user *)(uintptr_t)io.metadata,
1caf23
+					 meta, meta_len))
1caf23
 				status = -EFAULT;
1caf23
 		}
1caf23
 		dma_free_coherent(&dev->pci_dev->dev, meta_len, meta, meta_dma);
1caf23
-- 
1caf23
1.8.3.1
1caf23
1caf23
From d719f2b11f08861d97992f5973b7465fdb150a42 Mon Sep 17 00:00:00 2001
1caf23
From: Marcus Sundberg <marcus.sundberg@aptilo.com>
1caf23
Date: Mon, 8 Feb 2016 14:46:16 +0100
1caf23
Subject: [PATCH] (queue_store_unpriv_sgio): Check return from queue_var_store
1caf23
1caf23
---
1caf23
 block/blk-sysfs.c | 2 ++
1caf23
 1 file changed, 2 insertions(+)
1caf23
1caf23
diff --git a/block/blk-sysfs.c b/block/blk-sysfs.c
1caf23
index 13c5338..1f168c0 100644
1caf23
--- a/block/blk-sysfs.c
1caf23
+++ b/block/blk-sysfs.c
1caf23
@@ -207,6 +207,8 @@ queue_store_unpriv_sgio(struct request_queue *q, const char *page, size_t count)
1caf23
 		return -EPERM;
1caf23
 
1caf23
 	ret = queue_var_store(&val, page, count);
1caf23
+	if (ret < 0)
1caf23
+		return ret;
1caf23
 	spin_lock_irq(q->queue_lock);
1caf23
 	if (val)
1caf23
 		queue_flag_set(QUEUE_FLAG_UNPRIV_SGIO, q);
1caf23
-- 
1caf23
1.8.3.1
1caf23