Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
bd009496
Commit
bd009496
authored
Jun 20, 2006
by
Greg Kroah-Hartman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] USB: convert usb class devices to real devices
Signed-off-by:
Greg Kroah-Hartman
<
gregkh@suse.de
>
parent
c182274f
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
9 additions
and
9 deletions
+9
-9
drivers/usb/core/file.c
drivers/usb/core/file.c
+6
-7
include/linux/usb.h
include/linux/usb.h
+3
-2
No files found.
drivers/usb/core/file.c
View file @
bd009496
...
@@ -158,14 +158,13 @@ int usb_register_dev(struct usb_interface *intf,
...
@@ -158,14 +158,13 @@ int usb_register_dev(struct usb_interface *intf,
++
temp
;
++
temp
;
else
else
temp
=
name
;
temp
=
name
;
intf
->
class_dev
=
class_device_create
(
usb_class
,
NULL
,
intf
->
usb_dev
=
device_create
(
usb_class
,
&
intf
->
dev
,
MKDEV
(
USB_MAJOR
,
minor
),
MKDEV
(
USB_MAJOR
,
minor
),
"%s"
,
temp
);
&
intf
->
dev
,
"%s"
,
temp
);
if
(
IS_ERR
(
intf
->
usb_dev
))
{
if
(
IS_ERR
(
intf
->
class_dev
))
{
spin_lock
(
&
minor_lock
);
spin_lock
(
&
minor_lock
);
usb_minors
[
intf
->
minor
]
=
NULL
;
usb_minors
[
intf
->
minor
]
=
NULL
;
spin_unlock
(
&
minor_lock
);
spin_unlock
(
&
minor_lock
);
retval
=
PTR_ERR
(
intf
->
class
_dev
);
retval
=
PTR_ERR
(
intf
->
usb
_dev
);
}
}
exit:
exit:
return
retval
;
return
retval
;
...
@@ -206,8 +205,8 @@ void usb_deregister_dev(struct usb_interface *intf,
...
@@ -206,8 +205,8 @@ void usb_deregister_dev(struct usb_interface *intf,
spin_unlock
(
&
minor_lock
);
spin_unlock
(
&
minor_lock
);
snprintf
(
name
,
BUS_ID_SIZE
,
class_driver
->
name
,
intf
->
minor
-
minor_base
);
snprintf
(
name
,
BUS_ID_SIZE
,
class_driver
->
name
,
intf
->
minor
-
minor_base
);
class_
device_destroy
(
usb_class
,
MKDEV
(
USB_MAJOR
,
intf
->
minor
));
device_destroy
(
usb_class
,
MKDEV
(
USB_MAJOR
,
intf
->
minor
));
intf
->
class
_dev
=
NULL
;
intf
->
usb
_dev
=
NULL
;
intf
->
minor
=
-
1
;
intf
->
minor
=
-
1
;
}
}
EXPORT_SYMBOL
(
usb_deregister_dev
);
EXPORT_SYMBOL
(
usb_deregister_dev
);
...
...
include/linux/usb.h
View file @
bd009496
...
@@ -103,7 +103,8 @@ enum usb_interface_condition {
...
@@ -103,7 +103,8 @@ enum usb_interface_condition {
* @condition: binding state of the interface: not bound, binding
* @condition: binding state of the interface: not bound, binding
* (in probe()), bound to a driver, or unbinding (in disconnect())
* (in probe()), bound to a driver, or unbinding (in disconnect())
* @dev: driver model's view of this device
* @dev: driver model's view of this device
* @class_dev: driver model's class view of this device.
* @usb_dev: if an interface is bound to the USB major, this will point
* to the sysfs representation for that device.
*
*
* USB device drivers attach to interfaces on a physical device. Each
* USB device drivers attach to interfaces on a physical device. Each
* interface encapsulates a single high level function, such as feeding
* interface encapsulates a single high level function, such as feeding
...
@@ -143,7 +144,7 @@ struct usb_interface {
...
@@ -143,7 +144,7 @@ struct usb_interface {
* bound to */
* bound to */
enum
usb_interface_condition
condition
;
/* state of binding */
enum
usb_interface_condition
condition
;
/* state of binding */
struct
device
dev
;
/* interface specific device info */
struct
device
dev
;
/* interface specific device info */
struct
class_device
*
class_dev
;
struct
device
*
usb_dev
;
/* pointer to the usb class's device, if any */
};
};
#define to_usb_interface(d) container_of(d, struct usb_interface, dev)
#define to_usb_interface(d) container_of(d, struct usb_interface, dev)
#define interface_to_usbdev(intf) \
#define interface_to_usbdev(intf) \
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment