diff options
Diffstat (limited to 'drivers/usb/atm')
| -rw-r--r-- | drivers/usb/atm/Makefile | 1 | ||||
| -rw-r--r-- | drivers/usb/atm/cxacru.c | 43 | ||||
| -rw-r--r-- | drivers/usb/atm/speedtch.c | 35 | ||||
| -rw-r--r-- | drivers/usb/atm/ueagle-atm.c | 1 | ||||
| -rw-r--r-- | drivers/usb/atm/usbatm.c | 26 | ||||
| -rw-r--r-- | drivers/usb/atm/usbatm.h | 16 | ||||
| -rw-r--r-- | drivers/usb/atm/xusbatm.c | 16 | 
7 files changed, 38 insertions, 100 deletions
| diff --git a/drivers/usb/atm/Makefile b/drivers/usb/atm/Makefile index ac278946b06c..7ac65ce1aa8a 100644 --- a/drivers/usb/atm/Makefile +++ b/drivers/usb/atm/Makefile @@ -1,3 +1,4 @@ +# SPDX-License-Identifier: GPL-2.0  #  # Makefile for USB ATM/xDSL drivers  # diff --git a/drivers/usb/atm/cxacru.c b/drivers/usb/atm/cxacru.c index 5160a4a966b3..8af797252af2 100644 --- a/drivers/usb/atm/cxacru.c +++ b/drivers/usb/atm/cxacru.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0+  /******************************************************************************   *  cxacru.c  -  driver for USB ADSL modems based on   *               Conexant AccessRunner chipset @@ -6,21 +7,6 @@   *  Copyright (C) 2005 Duncan Sands, Roman Kagan (rkagan % mail ! ru)   *  Copyright (C) 2007 Simon Arlott   *  Copyright (C) 2009 Simon Arlott - * - *  This program is free software; you can redistribute it and/or modify it - *  under the terms of the GNU General Public License as published by the Free - *  Software Foundation; either version 2 of the License, or (at your option) - *  any later version. - * - *  This program is distributed in the hope that it will be useful, but WITHOUT - *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for - *  more details. - * - *  You should have received a copy of the GNU General Public License along with - *  this program; if not, write to the Free Software Foundation, Inc., 59 - *  Temple Place - Suite 330, Boston, MA  02111-1307, USA. - *   ******************************************************************************/  /* @@ -424,6 +410,7 @@ static ssize_t cxacru_sysfs_store_adsl_state(struct device *dev,  		case CXPOLL_STOPPING:  			/* abort stop request */  			instance->poll_state = CXPOLL_POLLING; +			/* fall through */  		case CXPOLL_POLLING:  		case CXPOLL_SHUTDOWN:  			/* don't start polling */ @@ -560,23 +547,30 @@ static void cxacru_blocking_completion(struct urb *urb)  	complete(urb->context);  } -static void cxacru_timeout_kill(unsigned long data) +struct cxacru_timer { +	struct timer_list timer; +	struct urb *urb; +}; + +static void cxacru_timeout_kill(struct timer_list *t)  { -	usb_unlink_urb((struct urb *) data); +	struct cxacru_timer *timer = from_timer(timer, t, timer); + +	usb_unlink_urb(timer->urb);  }  static int cxacru_start_wait_urb(struct urb *urb, struct completion *done,  				 int *actual_length)  { -	struct timer_list timer; +	struct cxacru_timer timer = { +		.urb = urb, +	}; -	init_timer(&timer); -	timer.expires = jiffies + msecs_to_jiffies(CMD_TIMEOUT); -	timer.data = (unsigned long) urb; -	timer.function = cxacru_timeout_kill; -	add_timer(&timer); +	timer_setup_on_stack(&timer.timer, cxacru_timeout_kill, 0); +	mod_timer(&timer.timer, jiffies + msecs_to_jiffies(CMD_TIMEOUT));  	wait_for_completion(done); -	del_timer_sync(&timer); +	del_timer_sync(&timer.timer); +	destroy_timer_on_stack(&timer.timer);  	if (actual_length)  		*actual_length = urb->actual_length; @@ -797,6 +791,7 @@ static int cxacru_atm_start(struct usbatm_data *usbatm_instance,  	case CXPOLL_STOPPING:  		/* abort stop request */  		instance->poll_state = CXPOLL_POLLING; +		/* fall through */  	case CXPOLL_POLLING:  	case CXPOLL_SHUTDOWN:  		/* don't start polling */ diff --git a/drivers/usb/atm/speedtch.c b/drivers/usb/atm/speedtch.c index 3676adb40d89..973548b5c15c 100644 --- a/drivers/usb/atm/speedtch.c +++ b/drivers/usb/atm/speedtch.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0+  /******************************************************************************   *  speedtch.c  -  Alcatel SpeedTouch USB xDSL modem driver   * @@ -6,21 +7,6 @@   *  Copyright (C) 2004, David Woodhouse   *   *  Based on "modem_run.c", copyright (C) 2001, Benoit Papillault - * - *  This program is free software; you can redistribute it and/or modify it - *  under the terms of the GNU General Public License as published by the Free - *  Software Foundation; either version 2 of the License, or (at your option) - *  any later version. - * - *  This program is distributed in the hope that it will be useful, but WITHOUT - *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for - *  more details. - * - *  You should have received a copy of the GNU General Public License along with - *  this program; if not, write to the Free Software Foundation, Inc., 59 - *  Temple Place - Suite 330, Boston, MA  02111-1307, USA. - *   ******************************************************************************/  #include <asm/page.h> @@ -571,9 +557,10 @@ static void speedtch_check_status(struct work_struct *work)  	}  } -static void speedtch_status_poll(unsigned long data) +static void speedtch_status_poll(struct timer_list *t)  { -	struct speedtch_instance_data *instance = (void *)data; +	struct speedtch_instance_data *instance = from_timer(instance, t, +						             status_check_timer);  	schedule_work(&instance->status_check_work); @@ -584,9 +571,10 @@ static void speedtch_status_poll(unsigned long data)  		atm_warn(instance->usbatm, "Too many failures - disabling line status polling\n");  } -static void speedtch_resubmit_int(unsigned long data) +static void speedtch_resubmit_int(struct timer_list *t)  { -	struct speedtch_instance_data *instance = (void *)data; +	struct speedtch_instance_data *instance = from_timer(instance, t, +							     resubmit_timer);  	struct urb *int_urb = instance->int_urb;  	int ret; @@ -874,16 +862,11 @@ static int speedtch_bind(struct usbatm_data *usbatm,  	usbatm->flags |= (use_isoc ? UDSL_USE_ISOC : 0);  	INIT_WORK(&instance->status_check_work, speedtch_check_status); -	init_timer(&instance->status_check_timer); - -	instance->status_check_timer.function = speedtch_status_poll; -	instance->status_check_timer.data = (unsigned long)instance; +	timer_setup(&instance->status_check_timer, speedtch_status_poll, 0);  	instance->last_status = 0xff;  	instance->poll_delay = MIN_POLL_DELAY; -	init_timer(&instance->resubmit_timer); -	instance->resubmit_timer.function = speedtch_resubmit_int; -	instance->resubmit_timer.data = (unsigned long)instance; +	timer_setup(&instance->resubmit_timer, speedtch_resubmit_int, 0);  	instance->int_urb = usb_alloc_urb(0, GFP_KERNEL); diff --git a/drivers/usb/atm/ueagle-atm.c b/drivers/usb/atm/ueagle-atm.c index ba7616395db2..ab75690044bb 100644 --- a/drivers/usb/atm/ueagle-atm.c +++ b/drivers/usb/atm/ueagle-atm.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause)  /*-   * Copyright (c) 2003, 2004   *	Damien Bergamini <damien.bergamini@free.fr>. All rights reserved. diff --git a/drivers/usb/atm/usbatm.c b/drivers/usb/atm/usbatm.c index 8607af758bbd..dbea28495e1d 100644 --- a/drivers/usb/atm/usbatm.c +++ b/drivers/usb/atm/usbatm.c @@ -1,24 +1,10 @@ +// SPDX-License-Identifier: GPL-2.0+  /******************************************************************************   *  usbatm.c - Generic USB xDSL driver core   *   *  Copyright (C) 2001, Alcatel   *  Copyright (C) 2003, Duncan Sands, SolNegro, Josep Comas   *  Copyright (C) 2004, David Woodhouse, Roman Kagan - * - *  This program is free software; you can redistribute it and/or modify it - *  under the terms of the GNU General Public License as published by the Free - *  Software Foundation; either version 2 of the License, or (at your option) - *  any later version. - * - *  This program is distributed in the hope that it will be useful, but WITHOUT - *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for - *  more details. - * - *  You should have received a copy of the GNU General Public License along with - *  this program; if not, write to the Free Software Foundation, Inc., 59 - *  Temple Place - Suite 330, Boston, MA  02111-1307, USA. - *   ******************************************************************************/  /* @@ -1003,18 +989,18 @@ static int usbatm_heavy_init(struct usbatm_data *instance)  	return 0;  } -static void usbatm_tasklet_schedule(unsigned long data) +static void usbatm_tasklet_schedule(struct timer_list *t)  { -	tasklet_schedule((struct tasklet_struct *) data); +	struct usbatm_channel *channel = from_timer(channel, t, delay); + +	tasklet_schedule(&channel->tasklet);  }  static void usbatm_init_channel(struct usbatm_channel *channel)  {  	spin_lock_init(&channel->lock);  	INIT_LIST_HEAD(&channel->list); -	channel->delay.function = usbatm_tasklet_schedule; -	channel->delay.data = (unsigned long) &channel->tasklet; -	init_timer(&channel->delay); +	timer_setup(&channel->delay, usbatm_tasklet_schedule, 0);  }  int usbatm_usb_probe(struct usb_interface *intf, const struct usb_device_id *id, diff --git a/drivers/usb/atm/usbatm.h b/drivers/usb/atm/usbatm.h index f3eecd967a8a..d3bdc4cc47aa 100644 --- a/drivers/usb/atm/usbatm.h +++ b/drivers/usb/atm/usbatm.h @@ -1,24 +1,10 @@ +// SPDX-License-Identifier: GPL-2.0+  /******************************************************************************   *  usbatm.h - Generic USB xDSL driver core   *   *  Copyright (C) 2001, Alcatel   *  Copyright (C) 2003, Duncan Sands, SolNegro, Josep Comas   *  Copyright (C) 2004, David Woodhouse - * - *  This program is free software; you can redistribute it and/or modify it - *  under the terms of the GNU General Public License as published by the Free - *  Software Foundation; either version 2 of the License, or (at your option) - *  any later version. - * - *  This program is distributed in the hope that it will be useful, but WITHOUT - *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for - *  more details. - * - *  You should have received a copy of the GNU General Public License along with - *  this program; if not, write to the Free Software Foundation, Inc., 59 - *  Temple Place - Suite 330, Boston, MA  02111-1307, USA. - *   ******************************************************************************/  #ifndef	_USBATM_H_ diff --git a/drivers/usb/atm/xusbatm.c b/drivers/usb/atm/xusbatm.c index c73c1ec3005e..ffc9810070a3 100644 --- a/drivers/usb/atm/xusbatm.c +++ b/drivers/usb/atm/xusbatm.c @@ -1,22 +1,8 @@ +// SPDX-License-Identifier: GPL-2.0+  /******************************************************************************   *  xusbatm.c -	dumb usbatm-based driver for modems initialized in userspace   *   *  Copyright (C) 2005 Duncan Sands, Roman Kagan (rkagan % mail ! ru) - * - *  This program is free software; you can redistribute it and/or modify it - *  under the terms of the GNU General Public License as published by the Free - *  Software Foundation; either version 2 of the License, or (at your option) - *  any later version. - * - *  This program is distributed in the hope that it will be useful, but WITHOUT - *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for - *  more details. - * - *  You should have received a copy of the GNU General Public License along with - *  this program; if not, write to the Free Software Foundation, Inc., 59 - *  Temple Place - Suite 330, Boston, MA  02111-1307, USA. - *   ******************************************************************************/  #include <linux/module.h> | 

