login
Login
/
Register
Search
Forums
News
Blogs
Features
Site
Home
»
Mailing list archives
»
linux-kernel
»
2008
»
May
»
14
Re: HSO: add option hso driver
view
thread
!MAILaRCHIVE_VOTE_RePLACE
Previous message: [
thread
] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
[view in full thread]
From:
Marcel Holtmann <marcel@...>
To: Paulius Zaleckas <paulius.zaleckas@...>
Cc: <linux-usb@...>, <netdev@...>, <linux-kernel@...>
Subject:
Re: HSO: add option hso driver
Date: Wednesday, May 14, 2008 - 1:36 pm
Hi Paulius,
quoted text
> > +/* called once for each interface upon device insertion */ > > +static int hso_probe(struct usb_interface *interface, > > + const struct usb_device_id *id) > > +{ > > + int mux, i, if_num, port_spec; > > + unsigned char port_mask; > > + struct hso_device *hso_dev = NULL; > > + struct hso_shared_int *shared_int; > > + struct hso_device *tmp_dev = NULL; > > + > > + if_num = interface->altsetting->desc.bInterfaceNumber; > > + > > + /* Get the interface/port specification from either driver_info or from > > + * the device itself */ > > + if (id->driver_info) > > + port_spec = ((u32 *)(id->driver_info))[if_num]; > > + else > > + port_spec = hso_get_config_data(interface); > > + > > + if (interface->cur_altsetting->desc.bInterfaceClass != 0xFF) { > > + dev_err(&interface->dev, "Not our interface\n"); > > + return -ENODEV; > > + } > > + /* Check if we need to switch to alt interfaces prior to port > > + * configuration */ > > + if (interface->num_altsetting > 1) > > + usb_set_interface(interface_to_usbdev(interface), if_num, 1); > > + interface->needs_remote_wakeup = 1; > > + > > + /* Allocate new hso device(s) */ > > + switch (port_spec & HSO_INTF_MASK) { > > + case HSO_INTF_MUX: > > + if ((port_spec & HSO_PORT_MASK) == HSO_PORT_NETWORK) { > > + /* Create the network device */ > > + if (!disable_net) { > > + hso_dev = hso_create_net_device(interface); > > + if (!hso_dev) > > + goto exit; > > + tmp_dev = hso_dev; > > + } > > + } > > + > > + if (hso_get_mux_ports(interface, &port_mask)) > > + /* TODO: de-allocate everything */ > > + goto exit; > > + > > + shared_int = hso_create_shared_int(interface); > > + if (!shared_int) > > + goto exit; > > + > > + for (i = 1, mux = 0; i < 0x100; i = i << 1, mux++) { > > + if (port_mask & i) { > > + hso_dev = hso_create_mux_serial_device( > > + interface, i, shared_int); > > + if (!hso_dev) > > + goto exit; > > + } > > + } > > + > > + if (tmp_dev) > > + hso_dev = tmp_dev; > > + break; > > + > > + case HSO_INTF_BULK: > > + /* It's a regular bulk interface */ > > + if (((port_spec & HSO_PORT_MASK) == HSO_PORT_NETWORK) > > + && !disable_net) > > + hso_dev = hso_create_net_device(interface); > > + else > > + hso_dev = > > + hso_create_bulk_serial_device(interface, port_spec); > > + if (!hso_dev) > > + goto exit; > > + break; > > + default: > > + goto exit; > > + } > > + > > + usb_driver_claim_interface(&hso_driver, interface, hso_dev); > > Is usb_driver_claim_interface really needed?
no it is not. That can be removed. Regards Marcel --
unsubscribe notice
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to
majordomo@vger.kernel.org
More majordomo info at
http://vger.kernel.org/majordomo-info.html
Please read the FAQ at
http://www.tux.org/lkml/
Previous message: [
thread
] [
date
] [
author
]
Next message: [
thread
] [
date
] [
author
]
Messages in current thread:
[PATCH] HSO: add option hso driver
, Greg KH
, (Tue May 13, 5:51 pm)
Re: [PATCH] HSO: add option hso driver
, Jan Engelhardt
, (Wed May 14, 11:58 am)
Re: [PATCH] HSO: add option hso driver
, Alan Cox
, (Tue May 13, 6:27 pm)
Re: [PATCH] HSO: add option hso driver
, Greg KH
, (Wed May 14, 12:52 am)
Re: [PATCH] HSO: add option hso driver
, Jeff Garzik
, (Tue May 13, 7:26 pm)
Re: [PATCH] HSO: add option hso driver
, Greg KH
, (Tue May 13, 9:58 pm)
HSO: add option hso driver
, Greg Kroah-Hartman
, (Wed May 14, 12:57 am)
Re: HSO: add option hso driver
, Jeff Garzik
, (Wed Jun 11, 10:51 pm)
Re: HSO: add option hso driver
, Paulius Zaleckas
, (Wed May 14, 9:59 am)
Re: HSO: add option hso driver
, Marcel Holtmann
, (Wed May 14, 1:36 pm)
Re: HSO: add option hso driver
, Filip Aben
, (Wed May 14, 11:12 am)
Navigation
Create content
Mailing list archives
Recent posts
Popular discussions
linux-kernel
:
Linus Torvalds
Linux 2.6.21-rc4
Greg Kroah-Hartman
[PATCH 008/196] Chinese: add translation of volatile-considered-harmful.txt
Andrew Morton
-mm merge plans for 2.6.23
Stephane Eranian
Re: [PATCH] fix up perfmon to build on -mm
git
:
linux-netdev
:
David Miller
[GIT]: Networking
David Miller
Re: [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock().
Gerrit Renker
[PATCH 27/37] dccp: Integration of dynamic feature activation - part 2 (server side)
Natalie Protasevich
[BUG] New Kernel Bugs
linux-fsdevel
:
Linus Torvalds
Re: silent semantic changes with reiser4
jim owens
Re: ext4 - getting at birth time (file create time) and getting/setting nanosecond...
Alan Cox
Re: impact of 4k sector size on the IO & FS stack
Peter Zijlstra
Re: + mm-balance_dirty_pages-reduce-calls-to-global_page_state-to-reduce-c ache-re...
Colocation donated by:
Who's online
There are currently
2 users
and
1097 guests
online.
Online users
bestelectrictoo
ernestot1
Syndicate