1 |
Author: mpagano |
2 |
Date: 2013-05-25 21:11:39 +0000 (Sat, 25 May 2013) |
3 |
New Revision: 2387 |
4 |
|
5 |
Added: |
6 |
genpatches-2.6/trunk/3.9/1003_linux-3.9.4.patch |
7 |
Modified: |
8 |
genpatches-2.6/trunk/3.9/0000_README |
9 |
Log: |
10 |
Linux patch 3.9.4 |
11 |
|
12 |
Modified: genpatches-2.6/trunk/3.9/0000_README |
13 |
=================================================================== |
14 |
--- genpatches-2.6/trunk/3.9/0000_README 2013-05-21 00:44:32 UTC (rev 2386) |
15 |
+++ genpatches-2.6/trunk/3.9/0000_README 2013-05-25 21:11:39 UTC (rev 2387) |
16 |
@@ -51,6 +51,10 @@ |
17 |
From: http://www.kernel.org |
18 |
Desc: Linux 3.9.3 |
19 |
|
20 |
+Patch: 1003_linux-3.9.4.patch |
21 |
+From: http://www.kernel.org |
22 |
+Desc: Linux 3.9.4 |
23 |
+ |
24 |
Patch: 1500_XATTR_USER_PREFIX.patch |
25 |
From: https://bugs.gentoo.org/show_bug.cgi?id=470644 |
26 |
Desc: Support for namespace user.pax.* on tmpfs. |
27 |
|
28 |
Added: genpatches-2.6/trunk/3.9/1003_linux-3.9.4.patch |
29 |
=================================================================== |
30 |
--- genpatches-2.6/trunk/3.9/1003_linux-3.9.4.patch (rev 0) |
31 |
+++ genpatches-2.6/trunk/3.9/1003_linux-3.9.4.patch 2013-05-25 21:11:39 UTC (rev 2387) |
32 |
@@ -0,0 +1,752 @@ |
33 |
+diff --git a/Makefile b/Makefile |
34 |
+index 01003d4..bfbfaf9 100644 |
35 |
+--- a/Makefile |
36 |
++++ b/Makefile |
37 |
+@@ -1,6 +1,6 @@ |
38 |
+ VERSION = 3 |
39 |
+ PATCHLEVEL = 9 |
40 |
+-SUBLEVEL = 3 |
41 |
++SUBLEVEL = 4 |
42 |
+ EXTRAVERSION = |
43 |
+ NAME = Unicycling Gorilla |
44 |
+ |
45 |
+diff --git a/arch/arm64/kernel/debug-monitors.c b/arch/arm64/kernel/debug-monitors.c |
46 |
+index 0c3ba9f..f4726dc 100644 |
47 |
+--- a/arch/arm64/kernel/debug-monitors.c |
48 |
++++ b/arch/arm64/kernel/debug-monitors.c |
49 |
+@@ -136,8 +136,6 @@ void disable_debug_monitors(enum debug_el el) |
50 |
+ */ |
51 |
+ static void clear_os_lock(void *unused) |
52 |
+ { |
53 |
+- asm volatile("msr mdscr_el1, %0" : : "r" (0)); |
54 |
+- isb(); |
55 |
+ asm volatile("msr oslar_el1, %0" : : "r" (0)); |
56 |
+ isb(); |
57 |
+ } |
58 |
+diff --git a/arch/arm64/mm/cache.S b/arch/arm64/mm/cache.S |
59 |
+index abe69b8..48a3860 100644 |
60 |
+--- a/arch/arm64/mm/cache.S |
61 |
++++ b/arch/arm64/mm/cache.S |
62 |
+@@ -52,7 +52,7 @@ loop1: |
63 |
+ add x2, x2, #4 // add 4 (line length offset) |
64 |
+ mov x4, #0x3ff |
65 |
+ and x4, x4, x1, lsr #3 // find maximum number on the way size |
66 |
+- clz x5, x4 // find bit position of way size increment |
67 |
++ clz w5, w4 // find bit position of way size increment |
68 |
+ mov x7, #0x7fff |
69 |
+ and x7, x7, x1, lsr #13 // extract max number of the index size |
70 |
+ loop2: |
71 |
+diff --git a/arch/arm64/mm/proc.S b/arch/arm64/mm/proc.S |
72 |
+index f1d8b9b..a82ae88 100644 |
73 |
+--- a/arch/arm64/mm/proc.S |
74 |
++++ b/arch/arm64/mm/proc.S |
75 |
+@@ -119,8 +119,7 @@ ENTRY(__cpu_setup) |
76 |
+ |
77 |
+ mov x0, #3 << 20 |
78 |
+ msr cpacr_el1, x0 // Enable FP/ASIMD |
79 |
+- mov x0, #1 |
80 |
+- msr oslar_el1, x0 // Set the debug OS lock |
81 |
++ msr mdscr_el1, xzr // Reset mdscr_el1 |
82 |
+ tlbi vmalle1is // invalidate I + D TLBs |
83 |
+ /* |
84 |
+ * Memory region attributes for LPAE: |
85 |
+diff --git a/arch/x86/include/asm/syscalls.h b/arch/x86/include/asm/syscalls.h |
86 |
+index 6cf0a9c..5a0be0a 100644 |
87 |
+--- a/arch/x86/include/asm/syscalls.h |
88 |
++++ b/arch/x86/include/asm/syscalls.h |
89 |
+@@ -37,8 +37,8 @@ asmlinkage int sys_get_thread_area(struct user_desc __user *); |
90 |
+ unsigned long sys_sigreturn(void); |
91 |
+ |
92 |
+ /* kernel/vm86_32.c */ |
93 |
+-int sys_vm86old(struct vm86_struct __user *); |
94 |
+-int sys_vm86(unsigned long, unsigned long); |
95 |
++asmlinkage long sys_vm86old(struct vm86_struct __user *); |
96 |
++asmlinkage long sys_vm86(unsigned long, unsigned long); |
97 |
+ |
98 |
+ #else /* CONFIG_X86_32 */ |
99 |
+ |
100 |
+diff --git a/arch/x86/kernel/head64.c b/arch/x86/kernel/head64.c |
101 |
+index 1c68ccb..8f3201d 100644 |
102 |
+--- a/arch/x86/kernel/head64.c |
103 |
++++ b/arch/x86/kernel/head64.c |
104 |
+@@ -34,7 +34,7 @@ |
105 |
+ extern pgd_t early_level4_pgt[PTRS_PER_PGD]; |
106 |
+ extern pmd_t early_dynamic_pgts[EARLY_DYNAMIC_PAGE_TABLES][PTRS_PER_PMD]; |
107 |
+ static unsigned int __initdata next_early_pgt = 2; |
108 |
+-pmdval_t __initdata early_pmd_flags = __PAGE_KERNEL_LARGE & ~(_PAGE_GLOBAL | _PAGE_NX); |
109 |
++pmdval_t early_pmd_flags = __PAGE_KERNEL_LARGE & ~(_PAGE_GLOBAL | _PAGE_NX); |
110 |
+ |
111 |
+ /* Wipe all early page tables except for the kernel symbol map */ |
112 |
+ static void __init reset_early_page_tables(void) |
113 |
+diff --git a/arch/x86/kernel/vm86_32.c b/arch/x86/kernel/vm86_32.c |
114 |
+index 1cf5766..3dbdd9c 100644 |
115 |
+--- a/arch/x86/kernel/vm86_32.c |
116 |
++++ b/arch/x86/kernel/vm86_32.c |
117 |
+@@ -33,6 +33,7 @@ |
118 |
+ #include <linux/capability.h> |
119 |
+ #include <linux/errno.h> |
120 |
+ #include <linux/interrupt.h> |
121 |
++#include <linux/syscalls.h> |
122 |
+ #include <linux/sched.h> |
123 |
+ #include <linux/kernel.h> |
124 |
+ #include <linux/signal.h> |
125 |
+@@ -48,7 +49,6 @@ |
126 |
+ #include <asm/io.h> |
127 |
+ #include <asm/tlbflush.h> |
128 |
+ #include <asm/irq.h> |
129 |
+-#include <asm/syscalls.h> |
130 |
+ |
131 |
+ /* |
132 |
+ * Known problems: |
133 |
+@@ -202,17 +202,16 @@ out: |
134 |
+ static int do_vm86_irq_handling(int subfunction, int irqnumber); |
135 |
+ static void do_sys_vm86(struct kernel_vm86_struct *info, struct task_struct *tsk); |
136 |
+ |
137 |
+-int sys_vm86old(struct vm86_struct __user *v86) |
138 |
++SYSCALL_DEFINE1(vm86old, struct vm86_struct __user *, v86) |
139 |
+ { |
140 |
+ struct kernel_vm86_struct info; /* declare this _on top_, |
141 |
+ * this avoids wasting of stack space. |
142 |
+ * This remains on the stack until we |
143 |
+ * return to 32 bit user space. |
144 |
+ */ |
145 |
+- struct task_struct *tsk; |
146 |
++ struct task_struct *tsk = current; |
147 |
+ int tmp, ret = -EPERM; |
148 |
+ |
149 |
+- tsk = current; |
150 |
+ if (tsk->thread.saved_sp0) |
151 |
+ goto out; |
152 |
+ tmp = copy_vm86_regs_from_user(&info.regs, &v86->regs, |
153 |
+@@ -227,11 +226,12 @@ int sys_vm86old(struct vm86_struct __user *v86) |
154 |
+ do_sys_vm86(&info, tsk); |
155 |
+ ret = 0; /* we never return here */ |
156 |
+ out: |
157 |
++ asmlinkage_protect(1, ret, v86); |
158 |
+ return ret; |
159 |
+ } |
160 |
+ |
161 |
+ |
162 |
+-int sys_vm86(unsigned long cmd, unsigned long arg) |
163 |
++SYSCALL_DEFINE2(vm86, unsigned long, cmd, unsigned long, arg) |
164 |
+ { |
165 |
+ struct kernel_vm86_struct info; /* declare this _on top_, |
166 |
+ * this avoids wasting of stack space. |
167 |
+@@ -278,6 +278,7 @@ int sys_vm86(unsigned long cmd, unsigned long arg) |
168 |
+ do_sys_vm86(&info, tsk); |
169 |
+ ret = 0; /* we never return here */ |
170 |
+ out: |
171 |
++ asmlinkage_protect(2, ret, cmd, arg); |
172 |
+ return ret; |
173 |
+ } |
174 |
+ |
175 |
+diff --git a/drivers/gpu/drm/nouveau/core/subdev/bios/init.c b/drivers/gpu/drm/nouveau/core/subdev/bios/init.c |
176 |
+index 9c41b58..ad6335f 100644 |
177 |
+--- a/drivers/gpu/drm/nouveau/core/subdev/bios/init.c |
178 |
++++ b/drivers/gpu/drm/nouveau/core/subdev/bios/init.c |
179 |
+@@ -1926,8 +1926,8 @@ init_zm_mask_add(struct nvbios_init *init) |
180 |
+ trace("ZM_MASK_ADD\tR[0x%06x] &= 0x%08x += 0x%08x\n", addr, mask, add); |
181 |
+ init->offset += 13; |
182 |
+ |
183 |
+- data = init_rd32(init, addr) & mask; |
184 |
+- data |= ((data + add) & ~mask); |
185 |
++ data = init_rd32(init, addr); |
186 |
++ data = (data & mask) | ((data + add) & ~mask); |
187 |
+ init_wr32(init, addr, data); |
188 |
+ } |
189 |
+ |
190 |
+diff --git a/drivers/gpu/drm/radeon/evergreen.c b/drivers/gpu/drm/radeon/evergreen.c |
191 |
+index aeaa386..0ea6bdf 100644 |
192 |
+--- a/drivers/gpu/drm/radeon/evergreen.c |
193 |
++++ b/drivers/gpu/drm/radeon/evergreen.c |
194 |
+@@ -2400,8 +2400,8 @@ int evergreen_mc_init(struct radeon_device *rdev) |
195 |
+ rdev->mc.real_vram_size = RREG32(CONFIG_MEMSIZE); |
196 |
+ } else { |
197 |
+ /* size in MB on evergreen/cayman/tn */ |
198 |
+- rdev->mc.mc_vram_size = RREG32(CONFIG_MEMSIZE) * 1024 * 1024; |
199 |
+- rdev->mc.real_vram_size = RREG32(CONFIG_MEMSIZE) * 1024 * 1024; |
200 |
++ rdev->mc.mc_vram_size = RREG32(CONFIG_MEMSIZE) * 1024ULL * 1024ULL; |
201 |
++ rdev->mc.real_vram_size = RREG32(CONFIG_MEMSIZE) * 1024ULL * 1024ULL; |
202 |
+ } |
203 |
+ rdev->mc.visible_vram_size = rdev->mc.aper_size; |
204 |
+ r700_vram_gtt_location(rdev, &rdev->mc); |
205 |
+diff --git a/drivers/gpu/drm/radeon/radeon_ttm.c b/drivers/gpu/drm/radeon/radeon_ttm.c |
206 |
+index 93f760e..6c0ce89 100644 |
207 |
+--- a/drivers/gpu/drm/radeon/radeon_ttm.c |
208 |
++++ b/drivers/gpu/drm/radeon/radeon_ttm.c |
209 |
+@@ -726,7 +726,7 @@ int radeon_ttm_init(struct radeon_device *rdev) |
210 |
+ return r; |
211 |
+ } |
212 |
+ DRM_INFO("radeon: %uM of VRAM memory ready\n", |
213 |
+- (unsigned)rdev->mc.real_vram_size / (1024 * 1024)); |
214 |
++ (unsigned) (rdev->mc.real_vram_size / (1024 * 1024))); |
215 |
+ r = ttm_bo_init_mm(&rdev->mman.bdev, TTM_PL_TT, |
216 |
+ rdev->mc.gtt_size >> PAGE_SHIFT); |
217 |
+ if (r) { |
218 |
+diff --git a/drivers/gpu/drm/radeon/si.c b/drivers/gpu/drm/radeon/si.c |
219 |
+index 3dd7ecc..287248c 100644 |
220 |
+--- a/drivers/gpu/drm/radeon/si.c |
221 |
++++ b/drivers/gpu/drm/radeon/si.c |
222 |
+@@ -2644,8 +2644,8 @@ static int si_mc_init(struct radeon_device *rdev) |
223 |
+ rdev->mc.aper_base = pci_resource_start(rdev->pdev, 0); |
224 |
+ rdev->mc.aper_size = pci_resource_len(rdev->pdev, 0); |
225 |
+ /* size in MB on si */ |
226 |
+- rdev->mc.mc_vram_size = RREG32(CONFIG_MEMSIZE) * 1024 * 1024; |
227 |
+- rdev->mc.real_vram_size = RREG32(CONFIG_MEMSIZE) * 1024 * 1024; |
228 |
++ rdev->mc.mc_vram_size = RREG32(CONFIG_MEMSIZE) * 1024ULL * 1024ULL; |
229 |
++ rdev->mc.real_vram_size = RREG32(CONFIG_MEMSIZE) * 1024ULL * 1024ULL; |
230 |
+ rdev->mc.visible_vram_size = rdev->mc.aper_size; |
231 |
+ si_vram_gtt_location(rdev, &rdev->mc); |
232 |
+ radeon_update_bandwidth_info(rdev); |
233 |
+diff --git a/drivers/hwmon/abituguru.c b/drivers/hwmon/abituguru.c |
234 |
+index 6119ff8..f3b3488 100644 |
235 |
+--- a/drivers/hwmon/abituguru.c |
236 |
++++ b/drivers/hwmon/abituguru.c |
237 |
+@@ -1411,14 +1411,18 @@ static int abituguru_probe(struct platform_device *pdev) |
238 |
+ pr_info("found Abit uGuru\n"); |
239 |
+ |
240 |
+ /* Register sysfs hooks */ |
241 |
+- for (i = 0; i < sysfs_attr_i; i++) |
242 |
+- if (device_create_file(&pdev->dev, |
243 |
+- &data->sysfs_attr[i].dev_attr)) |
244 |
++ for (i = 0; i < sysfs_attr_i; i++) { |
245 |
++ res = device_create_file(&pdev->dev, |
246 |
++ &data->sysfs_attr[i].dev_attr); |
247 |
++ if (res) |
248 |
+ goto abituguru_probe_error; |
249 |
+- for (i = 0; i < ARRAY_SIZE(abituguru_sysfs_attr); i++) |
250 |
+- if (device_create_file(&pdev->dev, |
251 |
+- &abituguru_sysfs_attr[i].dev_attr)) |
252 |
++ } |
253 |
++ for (i = 0; i < ARRAY_SIZE(abituguru_sysfs_attr); i++) { |
254 |
++ res = device_create_file(&pdev->dev, |
255 |
++ &abituguru_sysfs_attr[i].dev_attr); |
256 |
++ if (res) |
257 |
+ goto abituguru_probe_error; |
258 |
++ } |
259 |
+ |
260 |
+ data->hwmon_dev = hwmon_device_register(&pdev->dev); |
261 |
+ if (!IS_ERR(data->hwmon_dev)) |
262 |
+diff --git a/drivers/i2c/busses/i2c-designware-core.c b/drivers/i2c/busses/i2c-designware-core.c |
263 |
+index 94fd818..2db3628 100644 |
264 |
+--- a/drivers/i2c/busses/i2c-designware-core.c |
265 |
++++ b/drivers/i2c/busses/i2c-designware-core.c |
266 |
+@@ -361,7 +361,8 @@ static void i2c_dw_xfer_init(struct dw_i2c_dev *dev) |
267 |
+ /* Enable the adapter */ |
268 |
+ dw_writel(dev, 1, DW_IC_ENABLE); |
269 |
+ |
270 |
+- /* Enable interrupts */ |
271 |
++ /* Clear and enable interrupts */ |
272 |
++ i2c_dw_clear_int(dev); |
273 |
+ dw_writel(dev, DW_IC_INTR_DEFAULT_MASK, DW_IC_INTR_MASK); |
274 |
+ } |
275 |
+ |
276 |
+@@ -426,8 +427,14 @@ i2c_dw_xfer_msg(struct dw_i2c_dev *dev) |
277 |
+ cmd |= BIT(9); |
278 |
+ |
279 |
+ if (msgs[dev->msg_write_idx].flags & I2C_M_RD) { |
280 |
++ |
281 |
++ /* avoid rx buffer overrun */ |
282 |
++ if (rx_limit - dev->rx_outstanding <= 0) |
283 |
++ break; |
284 |
++ |
285 |
+ dw_writel(dev, cmd | 0x100, DW_IC_DATA_CMD); |
286 |
+ rx_limit--; |
287 |
++ dev->rx_outstanding++; |
288 |
+ } else |
289 |
+ dw_writel(dev, cmd | *buf++, DW_IC_DATA_CMD); |
290 |
+ tx_limit--; buf_len--; |
291 |
+@@ -480,8 +487,10 @@ i2c_dw_read(struct dw_i2c_dev *dev) |
292 |
+ |
293 |
+ rx_valid = dw_readl(dev, DW_IC_RXFLR); |
294 |
+ |
295 |
+- for (; len > 0 && rx_valid > 0; len--, rx_valid--) |
296 |
++ for (; len > 0 && rx_valid > 0; len--, rx_valid--) { |
297 |
+ *buf++ = dw_readl(dev, DW_IC_DATA_CMD); |
298 |
++ dev->rx_outstanding--; |
299 |
++ } |
300 |
+ |
301 |
+ if (len > 0) { |
302 |
+ dev->status |= STATUS_READ_IN_PROGRESS; |
303 |
+@@ -539,6 +548,7 @@ i2c_dw_xfer(struct i2c_adapter *adap, struct i2c_msg msgs[], int num) |
304 |
+ dev->msg_err = 0; |
305 |
+ dev->status = STATUS_IDLE; |
306 |
+ dev->abort_source = 0; |
307 |
++ dev->rx_outstanding = 0; |
308 |
+ |
309 |
+ ret = i2c_dw_wait_bus_not_busy(dev); |
310 |
+ if (ret < 0) |
311 |
+diff --git a/drivers/i2c/busses/i2c-designware-core.h b/drivers/i2c/busses/i2c-designware-core.h |
312 |
+index 9c1840e..e761ad1 100644 |
313 |
+--- a/drivers/i2c/busses/i2c-designware-core.h |
314 |
++++ b/drivers/i2c/busses/i2c-designware-core.h |
315 |
+@@ -60,6 +60,7 @@ |
316 |
+ * @adapter: i2c subsystem adapter node |
317 |
+ * @tx_fifo_depth: depth of the hardware tx fifo |
318 |
+ * @rx_fifo_depth: depth of the hardware rx fifo |
319 |
++ * @rx_outstanding: current master-rx elements in tx fifo |
320 |
+ */ |
321 |
+ struct dw_i2c_dev { |
322 |
+ struct device *dev; |
323 |
+@@ -88,6 +89,7 @@ struct dw_i2c_dev { |
324 |
+ u32 master_cfg; |
325 |
+ unsigned int tx_fifo_depth; |
326 |
+ unsigned int rx_fifo_depth; |
327 |
++ int rx_outstanding; |
328 |
+ }; |
329 |
+ |
330 |
+ #define ACCESS_SWAP 0x00000001 |
331 |
+diff --git a/drivers/net/ntb_netdev.c b/drivers/net/ntb_netdev.c |
332 |
+index ed947dd..f3cdf64 100644 |
333 |
+--- a/drivers/net/ntb_netdev.c |
334 |
++++ b/drivers/net/ntb_netdev.c |
335 |
+@@ -375,6 +375,8 @@ static void ntb_netdev_remove(struct pci_dev *pdev) |
336 |
+ if (dev == NULL) |
337 |
+ return; |
338 |
+ |
339 |
++ list_del(&dev->list); |
340 |
++ |
341 |
+ ndev = dev->ndev; |
342 |
+ |
343 |
+ unregister_netdev(ndev); |
344 |
+diff --git a/drivers/ntb/ntb_hw.c b/drivers/ntb/ntb_hw.c |
345 |
+index f802e7c..2dacd19 100644 |
346 |
+--- a/drivers/ntb/ntb_hw.c |
347 |
++++ b/drivers/ntb/ntb_hw.c |
348 |
+@@ -345,7 +345,7 @@ int ntb_read_remote_spad(struct ntb_device *ndev, unsigned int idx, u32 *val) |
349 |
+ */ |
350 |
+ void __iomem *ntb_get_mw_vbase(struct ntb_device *ndev, unsigned int mw) |
351 |
+ { |
352 |
+- if (mw > NTB_NUM_MW) |
353 |
++ if (mw >= NTB_NUM_MW) |
354 |
+ return NULL; |
355 |
+ |
356 |
+ return ndev->mw[mw].vbase; |
357 |
+@@ -362,7 +362,7 @@ void __iomem *ntb_get_mw_vbase(struct ntb_device *ndev, unsigned int mw) |
358 |
+ */ |
359 |
+ resource_size_t ntb_get_mw_size(struct ntb_device *ndev, unsigned int mw) |
360 |
+ { |
361 |
+- if (mw > NTB_NUM_MW) |
362 |
++ if (mw >= NTB_NUM_MW) |
363 |
+ return 0; |
364 |
+ |
365 |
+ return ndev->mw[mw].bar_sz; |
366 |
+@@ -380,7 +380,7 @@ resource_size_t ntb_get_mw_size(struct ntb_device *ndev, unsigned int mw) |
367 |
+ */ |
368 |
+ void ntb_set_mw_addr(struct ntb_device *ndev, unsigned int mw, u64 addr) |
369 |
+ { |
370 |
+- if (mw > NTB_NUM_MW) |
371 |
++ if (mw >= NTB_NUM_MW) |
372 |
+ return; |
373 |
+ |
374 |
+ dev_dbg(&ndev->pdev->dev, "Writing addr %Lx to BAR %d\n", addr, |
375 |
+@@ -1027,8 +1027,8 @@ static int ntb_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id) |
376 |
+ ndev->mw[i].vbase = |
377 |
+ ioremap_wc(pci_resource_start(pdev, MW_TO_BAR(i)), |
378 |
+ ndev->mw[i].bar_sz); |
379 |
+- dev_info(&pdev->dev, "MW %d size %d\n", i, |
380 |
+- (u32) pci_resource_len(pdev, MW_TO_BAR(i))); |
381 |
++ dev_info(&pdev->dev, "MW %d size %llu\n", i, |
382 |
++ pci_resource_len(pdev, MW_TO_BAR(i))); |
383 |
+ if (!ndev->mw[i].vbase) { |
384 |
+ dev_warn(&pdev->dev, "Cannot remap BAR %d\n", |
385 |
+ MW_TO_BAR(i)); |
386 |
+diff --git a/drivers/ntb/ntb_transport.c b/drivers/ntb/ntb_transport.c |
387 |
+index e0bdfd7..f8d7081 100644 |
388 |
+--- a/drivers/ntb/ntb_transport.c |
389 |
++++ b/drivers/ntb/ntb_transport.c |
390 |
+@@ -58,7 +58,7 @@ |
391 |
+ #include <linux/ntb.h> |
392 |
+ #include "ntb_hw.h" |
393 |
+ |
394 |
+-#define NTB_TRANSPORT_VERSION 2 |
395 |
++#define NTB_TRANSPORT_VERSION 3 |
396 |
+ |
397 |
+ static unsigned int transport_mtu = 0x401E; |
398 |
+ module_param(transport_mtu, uint, 0644); |
399 |
+@@ -173,10 +173,13 @@ struct ntb_payload_header { |
400 |
+ |
401 |
+ enum { |
402 |
+ VERSION = 0, |
403 |
+- MW0_SZ, |
404 |
+- MW1_SZ, |
405 |
+- NUM_QPS, |
406 |
+ QP_LINKS, |
407 |
++ NUM_QPS, |
408 |
++ NUM_MWS, |
409 |
++ MW0_SZ_HIGH, |
410 |
++ MW0_SZ_LOW, |
411 |
++ MW1_SZ_HIGH, |
412 |
++ MW1_SZ_LOW, |
413 |
+ MAX_SPAD, |
414 |
+ }; |
415 |
+ |
416 |
+@@ -297,7 +300,7 @@ int ntb_register_client_dev(char *device_name) |
417 |
+ { |
418 |
+ struct ntb_transport_client_dev *client_dev; |
419 |
+ struct ntb_transport *nt; |
420 |
+- int rc; |
421 |
++ int rc, i = 0; |
422 |
+ |
423 |
+ if (list_empty(&ntb_transport_list)) |
424 |
+ return -ENODEV; |
425 |
+@@ -315,7 +318,7 @@ int ntb_register_client_dev(char *device_name) |
426 |
+ dev = &client_dev->dev; |
427 |
+ |
428 |
+ /* setup and register client devices */ |
429 |
+- dev_set_name(dev, "%s", device_name); |
430 |
++ dev_set_name(dev, "%s%d", device_name, i); |
431 |
+ dev->bus = &ntb_bus_type; |
432 |
+ dev->release = ntb_client_release; |
433 |
+ dev->parent = &ntb_query_pdev(nt->ndev)->dev; |
434 |
+@@ -327,6 +330,7 @@ int ntb_register_client_dev(char *device_name) |
435 |
+ } |
436 |
+ |
437 |
+ list_add_tail(&client_dev->entry, &nt->client_devs); |
438 |
++ i++; |
439 |
+ } |
440 |
+ |
441 |
+ return 0; |
442 |
+@@ -486,12 +490,13 @@ static void ntb_transport_setup_qp_mw(struct ntb_transport *nt, |
443 |
+ (qp_num / NTB_NUM_MW * rx_size); |
444 |
+ rx_size -= sizeof(struct ntb_rx_info); |
445 |
+ |
446 |
+- qp->rx_buff = qp->remote_rx_info + sizeof(struct ntb_rx_info); |
447 |
+- qp->rx_max_frame = min(transport_mtu, rx_size); |
448 |
++ qp->rx_buff = qp->remote_rx_info + 1; |
449 |
++ /* Due to housekeeping, there must be atleast 2 buffs */ |
450 |
++ qp->rx_max_frame = min(transport_mtu, rx_size / 2); |
451 |
+ qp->rx_max_entry = rx_size / qp->rx_max_frame; |
452 |
+ qp->rx_index = 0; |
453 |
+ |
454 |
+- qp->remote_rx_info->entry = qp->rx_max_entry; |
455 |
++ qp->remote_rx_info->entry = qp->rx_max_entry - 1; |
456 |
+ |
457 |
+ /* setup the hdr offsets with 0's */ |
458 |
+ for (i = 0; i < qp->rx_max_entry; i++) { |
459 |
+@@ -502,6 +507,19 @@ static void ntb_transport_setup_qp_mw(struct ntb_transport *nt, |
460 |
+ |
461 |
+ qp->rx_pkts = 0; |
462 |
+ qp->tx_pkts = 0; |
463 |
++ qp->tx_index = 0; |
464 |
++} |
465 |
++ |
466 |
++static void ntb_free_mw(struct ntb_transport *nt, int num_mw) |
467 |
++{ |
468 |
++ struct ntb_transport_mw *mw = &nt->mw[num_mw]; |
469 |
++ struct pci_dev *pdev = ntb_query_pdev(nt->ndev); |
470 |
++ |
471 |
++ if (!mw->virt_addr) |
472 |
++ return; |
473 |
++ |
474 |
++ dma_free_coherent(&pdev->dev, mw->size, mw->virt_addr, mw->dma_addr); |
475 |
++ mw->virt_addr = NULL; |
476 |
+ } |
477 |
+ |
478 |
+ static int ntb_set_mw(struct ntb_transport *nt, int num_mw, unsigned int size) |
479 |
+@@ -509,12 +527,20 @@ static int ntb_set_mw(struct ntb_transport *nt, int num_mw, unsigned int size) |
480 |
+ struct ntb_transport_mw *mw = &nt->mw[num_mw]; |
481 |
+ struct pci_dev *pdev = ntb_query_pdev(nt->ndev); |
482 |
+ |
483 |
++ /* No need to re-setup */ |
484 |
++ if (mw->size == ALIGN(size, 4096)) |
485 |
++ return 0; |
486 |
++ |
487 |
++ if (mw->size != 0) |
488 |
++ ntb_free_mw(nt, num_mw); |
489 |
++ |
490 |
+ /* Alloc memory for receiving data. Must be 4k aligned */ |
491 |
+ mw->size = ALIGN(size, 4096); |
492 |
+ |
493 |
+ mw->virt_addr = dma_alloc_coherent(&pdev->dev, mw->size, &mw->dma_addr, |
494 |
+ GFP_KERNEL); |
495 |
+ if (!mw->virt_addr) { |
496 |
++ mw->size = 0; |
497 |
+ dev_err(&pdev->dev, "Unable to allocate MW buffer of size %d\n", |
498 |
+ (int) mw->size); |
499 |
+ return -ENOMEM; |
500 |
+@@ -604,25 +630,31 @@ static void ntb_transport_link_work(struct work_struct *work) |
501 |
+ u32 val; |
502 |
+ int rc, i; |
503 |
+ |
504 |
+- /* send the local info */ |
505 |
+- rc = ntb_write_remote_spad(ndev, VERSION, NTB_TRANSPORT_VERSION); |
506 |
+- if (rc) { |
507 |
+- dev_err(&pdev->dev, "Error writing %x to remote spad %d\n", |
508 |
+- 0, VERSION); |
509 |
+- goto out; |
510 |
+- } |
511 |
++ /* send the local info, in the opposite order of the way we read it */ |
512 |
++ for (i = 0; i < NTB_NUM_MW; i++) { |
513 |
++ rc = ntb_write_remote_spad(ndev, MW0_SZ_HIGH + (i * 2), |
514 |
++ ntb_get_mw_size(ndev, i) >> 32); |
515 |
++ if (rc) { |
516 |
++ dev_err(&pdev->dev, "Error writing %u to remote spad %d\n", |
517 |
++ (u32)(ntb_get_mw_size(ndev, i) >> 32), |
518 |
++ MW0_SZ_HIGH + (i * 2)); |
519 |
++ goto out; |
520 |
++ } |
521 |
+ |
522 |
+- rc = ntb_write_remote_spad(ndev, MW0_SZ, ntb_get_mw_size(ndev, 0)); |
523 |
+- if (rc) { |
524 |
+- dev_err(&pdev->dev, "Error writing %x to remote spad %d\n", |
525 |
+- (u32) ntb_get_mw_size(ndev, 0), MW0_SZ); |
526 |
+- goto out; |
527 |
++ rc = ntb_write_remote_spad(ndev, MW0_SZ_LOW + (i * 2), |
528 |
++ (u32) ntb_get_mw_size(ndev, i)); |
529 |
++ if (rc) { |
530 |
++ dev_err(&pdev->dev, "Error writing %u to remote spad %d\n", |
531 |
++ (u32) ntb_get_mw_size(ndev, i), |
532 |
++ MW0_SZ_LOW + (i * 2)); |
533 |
++ goto out; |
534 |
++ } |
535 |
+ } |
536 |
+ |
537 |
+- rc = ntb_write_remote_spad(ndev, MW1_SZ, ntb_get_mw_size(ndev, 1)); |
538 |
++ rc = ntb_write_remote_spad(ndev, NUM_MWS, NTB_NUM_MW); |
539 |
+ if (rc) { |
540 |
+ dev_err(&pdev->dev, "Error writing %x to remote spad %d\n", |
541 |
+- (u32) ntb_get_mw_size(ndev, 1), MW1_SZ); |
542 |
++ NTB_NUM_MW, NUM_MWS); |
543 |
+ goto out; |
544 |
+ } |
545 |
+ |
546 |
+@@ -633,16 +665,10 @@ static void ntb_transport_link_work(struct work_struct *work) |
547 |
+ goto out; |
548 |
+ } |
549 |
+ |
550 |
+- rc = ntb_read_local_spad(nt->ndev, QP_LINKS, &val); |
551 |
+- if (rc) { |
552 |
+- dev_err(&pdev->dev, "Error reading spad %d\n", QP_LINKS); |
553 |
+- goto out; |
554 |
+- } |
555 |
+- |
556 |
+- rc = ntb_write_remote_spad(ndev, QP_LINKS, val); |
557 |
++ rc = ntb_write_remote_spad(ndev, VERSION, NTB_TRANSPORT_VERSION); |
558 |
+ if (rc) { |
559 |
+ dev_err(&pdev->dev, "Error writing %x to remote spad %d\n", |
560 |
+- val, QP_LINKS); |
561 |
++ NTB_TRANSPORT_VERSION, VERSION); |
562 |
+ goto out; |
563 |
+ } |
564 |
+ |
565 |
+@@ -667,33 +693,43 @@ static void ntb_transport_link_work(struct work_struct *work) |
566 |
+ goto out; |
567 |
+ dev_dbg(&pdev->dev, "Remote max number of qps = %d\n", val); |
568 |
+ |
569 |
+- rc = ntb_read_remote_spad(ndev, MW0_SZ, &val); |
570 |
++ rc = ntb_read_remote_spad(ndev, NUM_MWS, &val); |
571 |
+ if (rc) { |
572 |
+- dev_err(&pdev->dev, "Error reading remote spad %d\n", MW0_SZ); |
573 |
++ dev_err(&pdev->dev, "Error reading remote spad %d\n", NUM_MWS); |
574 |
+ goto out; |
575 |
+ } |
576 |
+ |
577 |
+- if (!val) |
578 |
++ if (val != NTB_NUM_MW) |
579 |
+ goto out; |
580 |
+- dev_dbg(&pdev->dev, "Remote MW0 size = %d\n", val); |
581 |
++ dev_dbg(&pdev->dev, "Remote number of mws = %d\n", val); |
582 |
+ |
583 |
+- rc = ntb_set_mw(nt, 0, val); |
584 |
+- if (rc) |
585 |
+- goto out; |
586 |
++ for (i = 0; i < NTB_NUM_MW; i++) { |
587 |
++ u64 val64; |
588 |
+ |
589 |
+- rc = ntb_read_remote_spad(ndev, MW1_SZ, &val); |
590 |
+- if (rc) { |
591 |
+- dev_err(&pdev->dev, "Error reading remote spad %d\n", MW1_SZ); |
592 |
+- goto out; |
593 |
+- } |
594 |
++ rc = ntb_read_remote_spad(ndev, MW0_SZ_HIGH + (i * 2), &val); |
595 |
++ if (rc) { |
596 |
++ dev_err(&pdev->dev, "Error reading remote spad %d\n", |
597 |
++ MW0_SZ_HIGH + (i * 2)); |
598 |
++ goto out1; |
599 |
++ } |
600 |
+ |
601 |
+- if (!val) |
602 |
+- goto out; |
603 |
+- dev_dbg(&pdev->dev, "Remote MW1 size = %d\n", val); |
604 |
++ val64 = (u64) val << 32; |
605 |
+ |
606 |
+- rc = ntb_set_mw(nt, 1, val); |
607 |
+- if (rc) |
608 |
+- goto out; |
609 |
++ rc = ntb_read_remote_spad(ndev, MW0_SZ_LOW + (i * 2), &val); |
610 |
++ if (rc) { |
611 |
++ dev_err(&pdev->dev, "Error reading remote spad %d\n", |
612 |
++ MW0_SZ_LOW + (i * 2)); |
613 |
++ goto out1; |
614 |
++ } |
615 |
++ |
616 |
++ val64 |= val; |
617 |
++ |
618 |
++ dev_dbg(&pdev->dev, "Remote MW%d size = %llu\n", i, val64); |
619 |
++ |
620 |
++ rc = ntb_set_mw(nt, i, val64); |
621 |
++ if (rc) |
622 |
++ goto out1; |
623 |
++ } |
624 |
+ |
625 |
+ nt->transport_link = NTB_LINK_UP; |
626 |
+ |
627 |
+@@ -708,6 +744,9 @@ static void ntb_transport_link_work(struct work_struct *work) |
628 |
+ |
629 |
+ return; |
630 |
+ |
631 |
++out1: |
632 |
++ for (i = 0; i < NTB_NUM_MW; i++) |
633 |
++ ntb_free_mw(nt, i); |
634 |
+ out: |
635 |
+ if (ntb_hw_link_status(ndev)) |
636 |
+ schedule_delayed_work(&nt->link_work, |
637 |
+@@ -780,10 +819,10 @@ static void ntb_transport_init_queue(struct ntb_transport *nt, |
638 |
+ (qp_num / NTB_NUM_MW * tx_size); |
639 |
+ tx_size -= sizeof(struct ntb_rx_info); |
640 |
+ |
641 |
+- qp->tx_mw = qp->rx_info + sizeof(struct ntb_rx_info); |
642 |
+- qp->tx_max_frame = min(transport_mtu, tx_size); |
643 |
++ qp->tx_mw = qp->rx_info + 1; |
644 |
++ /* Due to housekeeping, there must be atleast 2 buffs */ |
645 |
++ qp->tx_max_frame = min(transport_mtu, tx_size / 2); |
646 |
+ qp->tx_max_entry = tx_size / qp->tx_max_frame; |
647 |
+- qp->tx_index = 0; |
648 |
+ |
649 |
+ if (nt->debugfs_dir) { |
650 |
+ char debugfs_name[4]; |
651 |
+@@ -897,10 +936,7 @@ void ntb_transport_free(void *transport) |
652 |
+ pdev = ntb_query_pdev(nt->ndev); |
653 |
+ |
654 |
+ for (i = 0; i < NTB_NUM_MW; i++) |
655 |
+- if (nt->mw[i].virt_addr) |
656 |
+- dma_free_coherent(&pdev->dev, nt->mw[i].size, |
657 |
+- nt->mw[i].virt_addr, |
658 |
+- nt->mw[i].dma_addr); |
659 |
++ ntb_free_mw(nt, i); |
660 |
+ |
661 |
+ kfree(nt->qps); |
662 |
+ ntb_unregister_transport(nt->ndev); |
663 |
+@@ -999,11 +1035,16 @@ out: |
664 |
+ static void ntb_transport_rx(unsigned long data) |
665 |
+ { |
666 |
+ struct ntb_transport_qp *qp = (struct ntb_transport_qp *)data; |
667 |
+- int rc; |
668 |
++ int rc, i; |
669 |
+ |
670 |
+- do { |
671 |
++ /* Limit the number of packets processed in a single interrupt to |
672 |
++ * provide fairness to others |
673 |
++ */ |
674 |
++ for (i = 0; i < qp->rx_max_entry; i++) { |
675 |
+ rc = ntb_process_rxc(qp); |
676 |
+- } while (!rc); |
677 |
++ if (rc) |
678 |
++ break; |
679 |
++ } |
680 |
+ } |
681 |
+ |
682 |
+ static void ntb_transport_rxc_db(void *data, int db_num) |
683 |
+@@ -1210,12 +1251,14 @@ EXPORT_SYMBOL_GPL(ntb_transport_create_queue); |
684 |
+ */ |
685 |
+ void ntb_transport_free_queue(struct ntb_transport_qp *qp) |
686 |
+ { |
687 |
+- struct pci_dev *pdev = ntb_query_pdev(qp->ndev); |
688 |
++ struct pci_dev *pdev; |
689 |
+ struct ntb_queue_entry *entry; |
690 |
+ |
691 |
+ if (!qp) |
692 |
+ return; |
693 |
+ |
694 |
++ pdev = ntb_query_pdev(qp->ndev); |
695 |
++ |
696 |
+ cancel_delayed_work_sync(&qp->link_work); |
697 |
+ |
698 |
+ ntb_unregister_db_callback(qp->ndev, qp->qp_num); |
699 |
+@@ -1371,12 +1414,13 @@ EXPORT_SYMBOL_GPL(ntb_transport_link_up); |
700 |
+ */ |
701 |
+ void ntb_transport_link_down(struct ntb_transport_qp *qp) |
702 |
+ { |
703 |
+- struct pci_dev *pdev = ntb_query_pdev(qp->ndev); |
704 |
++ struct pci_dev *pdev; |
705 |
+ int rc, val; |
706 |
+ |
707 |
+ if (!qp) |
708 |
+ return; |
709 |
+ |
710 |
++ pdev = ntb_query_pdev(qp->ndev); |
711 |
+ qp->client_ready = NTB_LINK_DOWN; |
712 |
+ |
713 |
+ rc = ntb_read_local_spad(qp->ndev, QP_LINKS, &val); |
714 |
+@@ -1408,6 +1452,9 @@ EXPORT_SYMBOL_GPL(ntb_transport_link_down); |
715 |
+ */ |
716 |
+ bool ntb_transport_link_query(struct ntb_transport_qp *qp) |
717 |
+ { |
718 |
++ if (!qp) |
719 |
++ return false; |
720 |
++ |
721 |
+ return qp->qp_link == NTB_LINK_UP; |
722 |
+ } |
723 |
+ EXPORT_SYMBOL_GPL(ntb_transport_link_query); |
724 |
+@@ -1422,6 +1469,9 @@ EXPORT_SYMBOL_GPL(ntb_transport_link_query); |
725 |
+ */ |
726 |
+ unsigned char ntb_transport_qp_num(struct ntb_transport_qp *qp) |
727 |
+ { |
728 |
++ if (!qp) |
729 |
++ return 0; |
730 |
++ |
731 |
+ return qp->qp_num; |
732 |
+ } |
733 |
+ EXPORT_SYMBOL_GPL(ntb_transport_qp_num); |
734 |
+@@ -1436,6 +1486,9 @@ EXPORT_SYMBOL_GPL(ntb_transport_qp_num); |
735 |
+ */ |
736 |
+ unsigned int ntb_transport_max_size(struct ntb_transport_qp *qp) |
737 |
+ { |
738 |
++ if (!qp) |
739 |
++ return 0; |
740 |
++ |
741 |
+ return qp->tx_max_frame - sizeof(struct ntb_payload_header); |
742 |
+ } |
743 |
+ EXPORT_SYMBOL_GPL(ntb_transport_max_size); |
744 |
+diff --git a/fs/btrfs/ioctl.c b/fs/btrfs/ioctl.c |
745 |
+index 2c02310..f49b62f 100644 |
746 |
+--- a/fs/btrfs/ioctl.c |
747 |
++++ b/fs/btrfs/ioctl.c |
748 |
+@@ -1796,7 +1796,11 @@ static noinline int copy_to_sk(struct btrfs_root *root, |
749 |
+ item_off = btrfs_item_ptr_offset(leaf, i); |
750 |
+ item_len = btrfs_item_size_nr(leaf, i); |
751 |
+ |
752 |
+- if (item_len > BTRFS_SEARCH_ARGS_BUFSIZE) |
753 |
++ btrfs_item_key_to_cpu(leaf, key, i); |
754 |
++ if (!key_in_sk(key, sk)) |
755 |
++ continue; |
756 |
++ |
757 |
++ if (sizeof(sh) + item_len > BTRFS_SEARCH_ARGS_BUFSIZE) |
758 |
+ item_len = 0; |
759 |
+ |
760 |
+ if (sizeof(sh) + item_len + *sk_offset > |
761 |
+@@ -1805,10 +1809,6 @@ static noinline int copy_to_sk(struct btrfs_root *root, |
762 |
+ goto overflow; |
763 |
+ } |
764 |
+ |
765 |
+- btrfs_item_key_to_cpu(leaf, key, i); |
766 |
+- if (!key_in_sk(key, sk)) |
767 |
+- continue; |
768 |
+- |
769 |
+ sh.objectid = key->objectid; |
770 |
+ sh.offset = key->offset; |
771 |
+ sh.type = key->type; |
772 |
+diff --git a/include/uapi/linux/virtio_console.h b/include/uapi/linux/virtio_console.h |
773 |
+index ee13ab6..c312f16 100644 |
774 |
+--- a/include/uapi/linux/virtio_console.h |
775 |
++++ b/include/uapi/linux/virtio_console.h |
776 |
+@@ -39,7 +39,7 @@ |
777 |
+ #define VIRTIO_CONSOLE_F_SIZE 0 /* Does host provide console size? */ |
778 |
+ #define VIRTIO_CONSOLE_F_MULTIPORT 1 /* Does host provide multiple ports? */ |
779 |
+ |
780 |
+-#define VIRTIO_CONSOLE_BAD_ID (~(u32)0) |
781 |
++#define VIRTIO_CONSOLE_BAD_ID (~(__u32)0) |
782 |
+ |
783 |
+ struct virtio_console_config { |
784 |
+ /* colums of the screens */ |