Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merge linux 3.0.59 #13

Merged
merged 73 commits into from
Jan 18, 2013
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
dc22f2d
powerpc: Fix CONFIG_RELOCATABLE=y CONFIG_CRASH_DUMP=n build
antonblanchard Nov 11, 2012
aea63e0
powerpc/vdso: Remove redundant locking in update_vsyscall_tz()
Nov 8, 2012
2c77bb3
s390/cio: fix pgid reserved check
Nov 30, 2012
63c5442
mm: compaction: fix echo 1 > compact_memory return error issue
LiuHui-Jason Jan 11, 2013
da0e14f
mm: use aligned zone start for pfn_to_bitidx calculation
labbott Jan 11, 2013
ae172f6
Revert "ath9k_hw: Update AR9003 high_power tx gain table"
Dec 6, 2012
46bea30
ath9k: ar9003: fix OTP register offsets for AR9340
juhosg Dec 9, 2012
f8ef1b3
firewire: net: Fix handling of fragmented multicast/broadcast packets.
gatzka Nov 28, 2012
b9ebaf5
SCSI: mvsas: fix undefined bit shift
xiw Nov 16, 2012
78c9672
SCSI: qla2xxx: Test and clear FCPORT_UPDATE_NEEDED atomically.
Nov 21, 2012
1bf3579
sata_promise: fix hardreset lockdep error
Sep 16, 2012
9b49bdf
libata: set dma_mode to 0xff in reset
Dec 3, 2012
454a7d5
libata: fix Null pointer dereference on disk error
xtfeng Dec 13, 2012
52ae560
target/tcm_fc: fix the lockdep warning due to inconsistent lock state
yizou Dec 11, 2012
2c44276
mfd: Only unregister platform devices allocated by the mfd core
charleskeepax Nov 9, 2012
9d4cbf8
ext4: fix memory leak in ext4_xattr_set_acl()'s error path
Nov 8, 2012
113b47f
SUNRPC: Ensure that we free the rpc_task after cleanups are done
Jan 4, 2013
43f5d33
jffs2: hold erase_completion_lock on exit
khoroshilov Nov 5, 2012
03bdf8e
i2400m: add Intel 6150 device IDs
dcbw Dec 14, 2012
f03ef10
drm/i915: make the panel fitter work on pipes B and C on IVB
pzanoni-intel Nov 20, 2012
84181e4
RDMA/nes: Fix for crash when registering zero length MR for CQ
tatyana-en Dec 6, 2012
39126ac
RDMA/nes: Fix for terminate timer crash
tatyana-en Dec 6, 2012
61cdfbb
ring-buffer: Fix race between integrity check and readers
Nov 30, 2012
1cf8193
dm ioctl: prevent unsafe change to dm_ioctl data_size
kergon Dec 21, 2012
a32f2fe
staging: vt6656: [BUG] out of bound array reference in RFbSetPower.
Oct 7, 2012
4f668e4
staging: vt6656: 64 bit fixes: use u32 for QWORD definition.
Nov 11, 2012
f25b877
staging: vt6656: 64 bit fixes : correct all type sizes
Nov 11, 2012
355bda5
staging: vt6656: 64 bit fixes: fix long warning messages.
Nov 11, 2012
afaac0d
staging: vt6656: 64bit fixes: key.c/h change unsigned long to u32
Nov 11, 2012
f125f80
staging: vt6656: 64bit fixes: vCommandTimerWait change calculation of…
Nov 11, 2012
fc65b0b
video: mxsfb: fix crash when unblanking the display
lw-karo Nov 22, 2012
8cbe638
ext4: fix extent tree corruption caused by hole punch
forrest1209 Dec 17, 2012
7c558b7
jbd2: fix assertion failure in jbd2_journal_flush()
jankara Dec 21, 2012
1ba9a27
ext4: do not try to write superblock on ro remount w/o journal
Dec 25, 2012
a4202fd
ext4: lock i_mutex when truncating orphan inodes
tytso Dec 27, 2012
39a7319
aoe: do not call bdi_init after blk_alloc_queue
ecashin Jan 12, 2013
de3ecca
udf: fix memory leak while allocating blocks during write
namjaejeon Oct 9, 2012
cdfcbd8
udf: don't increment lenExtents while writing to a hole
namjaejeon Oct 9, 2012
457a972
thp, memcg: split hugepage for memcg oom on cow
rientjes May 29, 2012
5e3fe67
x86, amd: Disable way access filter on Piledriver CPUs
aprzywar Oct 31, 2012
4a6cf0c
ACPI : do not use Lid and Sleep button for S5 wakeup
zhang-rui Dec 4, 2012
2e3cbde
rtnetlink: Compute and store minimum ifinfo dump size
Jan 4, 2013
a0d3aa1
rtnetlink: Fix problem with buffer allocation
Jan 4, 2013
b18401a
rtnetlink: fix rtnl_calcit() and rtnl_dump_ifinfo()
Jan 4, 2013
93b4026
epoll: prevent missed events on EPOLL_CTL_MOD
Jan 1, 2013
639fd95
ASoC: wm2000: Fix sense of speech clarity enable
broonie Jan 4, 2013
e2abf66
ALSA: pxa27x: fix ac97 cold reset
mike-dunn Jan 7, 2013
bf302ba
staging: comedi: prevent auto-unconfig of manually configured devices
ian-abbott Dec 4, 2012
2d8a66e
staging: comedi: comedi_test: fix race when cancelling command
ian-abbott Jan 4, 2013
3057105
staging: r8712u: Add new device ID
lwfinger Dec 29, 2012
36aa870
staging: speakup: avoid out-of-range access in synth_init()
zeldovich Jan 5, 2013
71a1306
staging: speakup: avoid out-of-range access in synth_add()
sthibaul Jan 7, 2013
0c3b520
radeon/kms: force rn50 chip to always report connected on analog output
Jan 8, 2013
9e2bd12
mac80211: use del_timer_sync for final sta cleanup timer deletion
jmberg-intel Dec 13, 2012
aa6e90f
USB: option: add Nexpring NP10T terminal id
Dec 3, 2012
eaf103d
USB: option: blacklist network interface on ZTE MF880
bmork Dec 19, 2012
40d3aad
USB: option: Add new MEDIATEK PID support
snokw Dec 26, 2012
54923de
USB: option: add Telekom Speedstick LTE II
bmork Dec 28, 2012
edce154
usb: ftdi_sio: Crucible Technologies COMET Caller ID - pid added
qdotme Jan 13, 2013
6d9a5f5
USB: cdc-acm: Add support for "PSC Scanning, Magellan 800i"
Dec 26, 2012
fca884e
usb: gadget: dummy: fix enumeration with g_multi
Nov 20, 2012
e16e202
USB: Increase reset timeout.
Nov 15, 2012
b30765e
USB: hub: handle claim of enabled remote wakeup after reset
Nov 29, 2012
961161c
xhci: Handle HS bulk/ctrl endpoints that don't NAK.
Dec 17, 2012
d668f92
GFS2: Test bufdata with buffer locked and gfs2_log_lock held
bmarzins Nov 7, 2012
5b8692b
intel-iommu: Free old page tables before creating superpage
Dec 19, 2012
9d2fdad
KVM: PPC: 44x: fix DCR read/write
agraf Oct 6, 2012
f387ee8
Revert "drm/i915: no lvds quirk for Zotac ZDBOX SD ID12/ID13"
danvet Jan 7, 2013
57a7502
staging: comedi: don't hijack hardware device private data
ian-abbott Mar 30, 2012
7633459
staging: comedi: Kconfig: COMEDI_NI_AT_A2150 should select COMEDI_FC
ian-abbott Jan 3, 2013
0829a6c
Linux 3.0.59
gregkh Jan 17, 2013
dcc44ae
Merge branch 'linux-3.0.59' into odroid-3.0.y
zehome Jan 18, 2013
42e2885
Fix inexistant modem_if thing
zehome Jan 18, 2013
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
VERSION = 3
PATCHLEVEL = 0
SUBLEVEL = 58
SUBLEVEL = 59
EXTRAVERSION =
NAME = Sneaky Weasel

Expand Down
2 changes: 1 addition & 1 deletion arch/powerpc/kernel/head_64.S
Original file line number Diff line number Diff line change
Expand Up @@ -425,7 +425,7 @@ _STATIC(__after_prom_start)
tovirt(r6,r6) /* on booke, we already run at PAGE_OFFSET */
#endif

#ifdef CONFIG_CRASH_DUMP
#ifdef CONFIG_RELOCATABLE
/*
* Check if the kernel has to be running as relocatable kernel based on the
* variable __run_at_load, if it is set the kernel is treated as relocatable
Expand Down
5 changes: 0 additions & 5 deletions arch/powerpc/kernel/time.c
Original file line number Diff line number Diff line change
Expand Up @@ -859,13 +859,8 @@ void update_vsyscall(struct timespec *wall_time, struct timespec *wtm,

void update_vsyscall_tz(void)
{
/* Make userspace gettimeofday spin until we're done. */
++vdso_data->tb_update_count;
smp_mb();
vdso_data->tz_minuteswest = sys_tz.tz_minuteswest;
vdso_data->tz_dsttime = sys_tz.tz_dsttime;
smp_mb();
++vdso_data->tb_update_count;
}

static void __init clocksource_init(void)
Expand Down
2 changes: 2 additions & 0 deletions arch/powerpc/kvm/44x_emulate.c
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ int kvmppc_core_emulate_op(struct kvm_run *run, struct kvm_vcpu *vcpu,
run->dcr.dcrn = dcrn;
run->dcr.data = 0;
run->dcr.is_write = 0;
vcpu->arch.dcr_is_write = 0;
vcpu->arch.io_gpr = rt;
vcpu->arch.dcr_needed = 1;
kvmppc_account_exit(vcpu, DCR_EXITS);
Expand All @@ -100,6 +101,7 @@ int kvmppc_core_emulate_op(struct kvm_run *run, struct kvm_vcpu *vcpu,
run->dcr.dcrn = dcrn;
run->dcr.data = kvmppc_get_gpr(vcpu, rs);
run->dcr.is_write = 1;
vcpu->arch.dcr_is_write = 1;
vcpu->arch.dcr_needed = 1;
kvmppc_account_exit(vcpu, DCR_EXITS);
emulated = EMULATE_DO_DCR;
Expand Down
14 changes: 14 additions & 0 deletions arch/x86/kernel/cpu/amd.c
Original file line number Diff line number Diff line change
Expand Up @@ -568,6 +568,20 @@ static void __cpuinit init_amd(struct cpuinfo_x86 *c)
}
}

/*
* The way access filter has a performance penalty on some workloads.
* Disable it on the affected CPUs.
*/
if ((c->x86 == 0x15) &&
(c->x86_model >= 0x02) && (c->x86_model < 0x20)) {
u64 val;

if (!rdmsrl_safe(0xc0011021, &val) && !(val & 0x1E)) {
val |= 0x1E;
checking_wrmsrl(0xc0011021, val);
}
}

cpu_detect_cache_sizes(c);

/* Multi core CPU? */
Expand Down
7 changes: 6 additions & 1 deletion drivers/acpi/scan.c
Original file line number Diff line number Diff line change
Expand Up @@ -789,8 +789,8 @@ acpi_bus_extract_wakeup_device_power_package(acpi_handle handle,
static void acpi_bus_set_run_wake_flags(struct acpi_device *device)
{
struct acpi_device_id button_device_ids[] = {
{"PNP0C0D", 0},
{"PNP0C0C", 0},
{"PNP0C0D", 0},
{"PNP0C0E", 0},
{"", 0},
};
Expand All @@ -802,6 +802,11 @@ static void acpi_bus_set_run_wake_flags(struct acpi_device *device)
/* Power button, Lid switch always enable wakeup */
if (!acpi_match_device_ids(device, button_device_ids)) {
device->wakeup.flags.run_wake = 1;
if (!acpi_match_device_ids(device, &button_device_ids[1])) {
/* Do not use Lid/sleep button for S5 wakeup */
if (device->wakeup.sleep_state == ACPI_STATE_S5)
device->wakeup.sleep_state = ACPI_STATE_S4;
}
device_set_wakeup_capable(&device->dev, true);
return;
}
Expand Down
1 change: 1 addition & 0 deletions drivers/ata/libata-core.c
Original file line number Diff line number Diff line change
Expand Up @@ -2543,6 +2543,7 @@ int ata_bus_probe(struct ata_port *ap)
* bus as we may be talking too fast.
*/
dev->pio_mode = XFER_PIO_0;
dev->dma_mode = 0xff;

/* If the controller has a pio mode setup function
* then use it to set the chipset to rights. Don't
Expand Down
1 change: 1 addition & 0 deletions drivers/ata/libata-eh.c
Original file line number Diff line number Diff line change
Expand Up @@ -2602,6 +2602,7 @@ int ata_eh_reset(struct ata_link *link, int classify,
* bus as we may be talking too fast.
*/
dev->pio_mode = XFER_PIO_0;
dev->dma_mode = 0xff;

/* If the controller has a pio mode setup function
* then use it to set the chipset to rights. Don't
Expand Down
6 changes: 4 additions & 2 deletions drivers/ata/libata-scsi.c
Original file line number Diff line number Diff line change
Expand Up @@ -308,7 +308,8 @@ ata_scsi_activity_show(struct device *dev, struct device_attribute *attr,
struct ata_port *ap = ata_shost_to_port(sdev->host);
struct ata_device *atadev = ata_scsi_find_dev(ap, sdev);

if (ap->ops->sw_activity_show && (ap->flags & ATA_FLAG_SW_ACTIVITY))
if (atadev && ap->ops->sw_activity_show &&
(ap->flags & ATA_FLAG_SW_ACTIVITY))
return ap->ops->sw_activity_show(atadev, buf);
return -EINVAL;
}
Expand All @@ -323,7 +324,8 @@ ata_scsi_activity_store(struct device *dev, struct device_attribute *attr,
enum sw_activity val;
int rc;

if (ap->ops->sw_activity_store && (ap->flags & ATA_FLAG_SW_ACTIVITY)) {
if (atadev && ap->ops->sw_activity_store &&
(ap->flags & ATA_FLAG_SW_ACTIVITY)) {
val = simple_strtoul(buf, NULL, 0);
switch (val) {
case OFF: case BLINK_ON: case BLINK_OFF:
Expand Down
15 changes: 13 additions & 2 deletions drivers/ata/sata_promise.c
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,10 @@ struct pdc_port_priv {
dma_addr_t pkt_dma;
};

struct pdc_host_priv {
spinlock_t hard_reset_lock;
};

static int pdc_sata_scr_read(struct ata_link *link, unsigned int sc_reg, u32 *val);
static int pdc_sata_scr_write(struct ata_link *link, unsigned int sc_reg, u32 val);
static int pdc_ata_init_one(struct pci_dev *pdev, const struct pci_device_id *ent);
Expand Down Expand Up @@ -801,9 +805,10 @@ static void pdc_hard_reset_port(struct ata_port *ap)
void __iomem *host_mmio = ap->host->iomap[PDC_MMIO_BAR];
void __iomem *pcictl_b1_mmio = host_mmio + PDC_PCI_CTL + 1;
unsigned int ata_no = pdc_ata_port_to_ata_no(ap);
struct pdc_host_priv *hpriv = ap->host->private_data;
u8 tmp;

spin_lock(&ap->host->lock);
spin_lock(&hpriv->hard_reset_lock);

tmp = readb(pcictl_b1_mmio);
tmp &= ~(0x10 << ata_no);
Expand All @@ -814,7 +819,7 @@ static void pdc_hard_reset_port(struct ata_port *ap)
writeb(tmp, pcictl_b1_mmio);
readb(pcictl_b1_mmio); /* flush */

spin_unlock(&ap->host->lock);
spin_unlock(&hpriv->hard_reset_lock);
}

static int pdc_sata_hardreset(struct ata_link *link, unsigned int *class,
Expand Down Expand Up @@ -1183,6 +1188,7 @@ static int pdc_ata_init_one(struct pci_dev *pdev,
const struct ata_port_info *pi = &pdc_port_info[ent->driver_data];
const struct ata_port_info *ppi[PDC_MAX_PORTS];
struct ata_host *host;
struct pdc_host_priv *hpriv;
void __iomem *host_mmio;
int n_ports, i, rc;
int is_sataii_tx4;
Expand Down Expand Up @@ -1220,6 +1226,11 @@ static int pdc_ata_init_one(struct pci_dev *pdev,
dev_printk(KERN_ERR, &pdev->dev, "failed to allocate host\n");
return -ENOMEM;
}
hpriv = devm_kzalloc(&pdev->dev, sizeof *hpriv, GFP_KERNEL);
if (!hpriv)
return -ENOMEM;
spin_lock_init(&hpriv->hard_reset_lock);
host->private_data = hpriv;
host->iomap = pcim_iomap_table(pdev);

is_sataii_tx4 = pdc_is_sataii_tx4(pi->flags);
Expand Down
2 changes: 1 addition & 1 deletion drivers/block/aoe/aoe.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/* Copyright (c) 2007 Coraid, Inc. See COPYING for GPL terms. */
#define VERSION "47"
#define VERSION "47q"
#define AOE_MAJOR 152
#define DEVICE_NAME "aoe"

Expand Down
5 changes: 0 additions & 5 deletions drivers/block/aoe/aoeblk.c
Original file line number Diff line number Diff line change
Expand Up @@ -277,8 +277,6 @@ aoeblk_gdalloc(void *vp)
goto err_mempool;
blk_queue_make_request(d->blkq, aoeblk_make_request);
d->blkq->backing_dev_info.name = "aoe";
if (bdi_init(&d->blkq->backing_dev_info))
goto err_blkq;
spin_lock_irqsave(&d->lock, flags);
gd->major = AOE_MAJOR;
gd->first_minor = d->sysminor * AOE_PARTITIONS;
Expand All @@ -299,9 +297,6 @@ aoeblk_gdalloc(void *vp)
aoedisk_add_sysfs(d);
return;

err_blkq:
blk_cleanup_queue(d->blkq);
d->blkq = NULL;
err_mempool:
mempool_destroy(d->bufpool);
err_disk:
Expand Down
13 changes: 9 additions & 4 deletions drivers/firewire/net.c
Original file line number Diff line number Diff line change
Expand Up @@ -863,8 +863,8 @@ static void fwnet_receive_broadcast(struct fw_iso_context *context,
if (specifier_id == IANA_SPECIFIER_ID && ver == RFC2734_SW_VERSION) {
buf_ptr += 2;
length -= IEEE1394_GASP_HDR_SIZE;
fwnet_incoming_packet(dev, buf_ptr, length,
source_node_id, -1, true);
fwnet_incoming_packet(dev, buf_ptr, length, source_node_id,
context->card->generation, true);
}

packet.payload_length = dev->rcv_buffer_size;
Expand Down Expand Up @@ -959,7 +959,12 @@ static void fwnet_transmit_packet_done(struct fwnet_packet_task *ptask)
break;
}

skb_pull(skb, ptask->max_payload);
if (ptask->dest_node == IEEE1394_ALL_NODES) {
skb_pull(skb,
ptask->max_payload + IEEE1394_GASP_HDR_SIZE);
} else {
skb_pull(skb, ptask->max_payload);
}
if (ptask->outstanding_pkts > 1) {
fwnet_make_sf_hdr(&ptask->hdr, RFC2374_HDR_INTFRAG,
dg_size, fg_off, datagram_label);
Expand Down Expand Up @@ -1062,7 +1067,7 @@ static int fwnet_send_packet(struct fwnet_packet_task *ptask)
smp_rmb();
node_id = dev->card->node_id;

p = skb_push(ptask->skb, 8);
p = skb_push(ptask->skb, IEEE1394_GASP_HDR_SIZE);
put_unaligned_be32(node_id << 16 | IANA_SPECIFIER_ID >> 8, p);
put_unaligned_be32((IANA_SPECIFIER_ID & 0xff) << 24
| RFC2734_SW_VERSION, &p[4]);
Expand Down
2 changes: 2 additions & 0 deletions drivers/gpu/drm/i915/i915_reg.h
Original file line number Diff line number Diff line change
Expand Up @@ -2754,6 +2754,8 @@
#define _PFA_CTL_1 0x68080
#define _PFB_CTL_1 0x68880
#define PF_ENABLE (1<<31)
#define PF_PIPE_SEL_MASK_IVB (3<<29)
#define PF_PIPE_SEL_IVB(pipe) ((pipe)<<29)
#define PF_FILTER_MASK (3<<23)
#define PF_FILTER_PROGRAMMED (0<<23)
#define PF_FILTER_MED_3x3 (1<<23)
Expand Down
6 changes: 5 additions & 1 deletion drivers/gpu/drm/i915/intel_display.c
Original file line number Diff line number Diff line change
Expand Up @@ -2696,7 +2696,11 @@ static void ironlake_crtc_enable(struct drm_crtc *crtc)
* as some pre-programmed values are broken,
* e.g. x201.
*/
I915_WRITE(PF_CTL(pipe), PF_ENABLE | PF_FILTER_MED_3x3);
if (IS_IVYBRIDGE(dev))
I915_WRITE(PF_CTL(pipe), PF_ENABLE | PF_FILTER_MED_3x3 |
PF_PIPE_SEL_IVB(pipe));
else
I915_WRITE(PF_CTL(pipe), PF_ENABLE | PF_FILTER_MED_3x3);
I915_WRITE(PF_WIN_POS(pipe), dev_priv->pch_pf_pos);
I915_WRITE(PF_WIN_SZ(pipe), dev_priv->pch_pf_size);
}
Expand Down
8 changes: 0 additions & 8 deletions drivers/gpu/drm/i915/intel_lvds.c
Original file line number Diff line number Diff line change
Expand Up @@ -751,14 +751,6 @@ static const struct dmi_system_id intel_no_lvds[] = {
DMI_MATCH(DMI_BOARD_NAME, "MS-7469"),
},
},
{
.callback = intel_no_lvds_dmi_callback,
.ident = "ZOTAC ZBOXSD-ID12/ID13",
.matches = {
DMI_MATCH(DMI_BOARD_VENDOR, "ZOTAC"),
DMI_MATCH(DMI_BOARD_NAME, "ZBOXSD-ID12/ID13"),
},
},
{
.callback = intel_no_lvds_dmi_callback,
.ident = "Gigabyte GA-D525TUD",
Expand Down
8 changes: 8 additions & 0 deletions drivers/gpu/drm/radeon/radeon_legacy_encoders.c
Original file line number Diff line number Diff line change
Expand Up @@ -617,6 +617,14 @@ static enum drm_connector_status radeon_legacy_primary_dac_detect(struct drm_enc
enum drm_connector_status found = connector_status_disconnected;
bool color = true;

/* just don't bother on RN50 those chip are often connected to remoting
* console hw and often we get failure to load detect those. So to make
* everyone happy report the encoder as always connected.
*/
if (ASIC_IS_RN50(rdev)) {
return connector_status_connected;
}

/* save the regs we need */
vclk_ecp_cntl = RREG32_PLL(RADEON_VCLK_ECP_CNTL);
crtc_ext_cntl = RREG32(RADEON_CRTC_EXT_CNTL);
Expand Down
2 changes: 1 addition & 1 deletion drivers/infiniband/core/netlink.c
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,7 @@ static int ibnl_rcv_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
return -EINVAL;
return netlink_dump_start(nls, skb, nlh,
client->cb_table[op].dump,
NULL);
NULL, 0);
}
}

Expand Down
1 change: 1 addition & 0 deletions drivers/infiniband/hw/nes/nes.h
Original file line number Diff line number Diff line change
Expand Up @@ -511,6 +511,7 @@ void nes_iwarp_ce_handler(struct nes_device *, struct nes_hw_cq *);
int nes_destroy_cqp(struct nes_device *);
int nes_nic_cm_xmit(struct sk_buff *, struct net_device *);
void nes_recheck_link_status(struct work_struct *work);
void nes_terminate_timeout(unsigned long context);

/* nes_nic.c */
struct net_device *nes_netdev_init(struct nes_device *, void __iomem *);
Expand Down
9 changes: 2 additions & 7 deletions drivers/infiniband/hw/nes/nes_hw.c
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,6 @@ static void nes_process_iwarp_aeqe(struct nes_device *nesdev,
static void process_critical_error(struct nes_device *nesdev);
static void nes_process_mac_intr(struct nes_device *nesdev, u32 mac_number);
static unsigned int nes_reset_adapter_ne020(struct nes_device *nesdev, u8 *OneG_Mode);
static void nes_terminate_timeout(unsigned long context);
static void nes_terminate_start_timer(struct nes_qp *nesqp);

#ifdef CONFIG_INFINIBAND_NES_DEBUG
Expand Down Expand Up @@ -3496,7 +3495,7 @@ static void nes_terminate_received(struct nes_device *nesdev,
}

/* Timeout routine in case terminate fails to complete */
static void nes_terminate_timeout(unsigned long context)
void nes_terminate_timeout(unsigned long context)
{
struct nes_qp *nesqp = (struct nes_qp *)(unsigned long)context;

Expand All @@ -3506,11 +3505,7 @@ static void nes_terminate_timeout(unsigned long context)
/* Set a timer in case hw cannot complete the terminate sequence */
static void nes_terminate_start_timer(struct nes_qp *nesqp)
{
init_timer(&nesqp->terminate_timer);
nesqp->terminate_timer.function = nes_terminate_timeout;
nesqp->terminate_timer.expires = jiffies + HZ;
nesqp->terminate_timer.data = (unsigned long)nesqp;
add_timer(&nesqp->terminate_timer);
mod_timer(&nesqp->terminate_timer, (jiffies + HZ));
}

/**
Expand Down
9 changes: 8 additions & 1 deletion drivers/infiniband/hw/nes/nes_verbs.c
Original file line number Diff line number Diff line change
Expand Up @@ -1414,6 +1414,9 @@ static struct ib_qp *nes_create_qp(struct ib_pd *ibpd,
}

nesqp->sig_all = (init_attr->sq_sig_type == IB_SIGNAL_ALL_WR);
init_timer(&nesqp->terminate_timer);
nesqp->terminate_timer.function = nes_terminate_timeout;
nesqp->terminate_timer.data = (unsigned long)nesqp;

/* update the QP table */
nesdev->nesadapter->qp_table[nesqp->hwqp.qp_id-NES_FIRST_QPN] = nesqp;
Expand All @@ -1423,7 +1426,6 @@ static struct ib_qp *nes_create_qp(struct ib_pd *ibpd,
return &nesqp->ibqp;
}


/**
* nes_clean_cq
*/
Expand Down Expand Up @@ -2568,6 +2570,11 @@ static struct ib_mr *nes_reg_user_mr(struct ib_pd *pd, u64 start, u64 length,
return ibmr;
case IWNES_MEMREG_TYPE_QP:
case IWNES_MEMREG_TYPE_CQ:
if (!region->length) {
nes_debug(NES_DBG_MR, "Unable to register zero length region for CQ\n");
ib_umem_release(region);
return ERR_PTR(-EINVAL);
}
nespbl = kzalloc(sizeof(*nespbl), GFP_KERNEL);
if (!nespbl) {
nes_debug(NES_DBG_MR, "Unable to allocate PBL\n");
Expand Down
8 changes: 8 additions & 0 deletions drivers/md/dm-ioctl.c
Original file line number Diff line number Diff line change
Expand Up @@ -1524,6 +1524,14 @@ static int copy_params(struct dm_ioctl __user *user, struct dm_ioctl **param)
if (copy_from_user(dmi, user, tmp.data_size))
goto bad;

/*
* Abort if something changed the ioctl data while it was being copied.
*/
if (dmi->data_size != tmp.data_size) {
DMERR("rejecting ioctl: data size modified while processing parameters");
goto bad;
}

/* Wipe the user buffer so we do not return it to userspace */
if (secure_data && clear_user(user, tmp.data_size))
goto bad;
Expand Down
Loading