Gentoo Archives: gentoo-commits

From: "Mike Pagano (mpagano)" <mpagano@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] linux-patches r2387 - genpatches-2.6/trunk/3.9
Date: Sat, 25 May 2013 21:11:49
Message-Id: 20130525211139.B19BD2171D@flycatcher.gentoo.org
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 */