Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
0dad95dc
Commit
0dad95dc
authored
Sep 13, 2014
by
Greg Kroah-Hartman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
greybus: es1: allocate cport out urbs properly
parent
11299732
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
34 additions
and
5 deletions
+34
-5
drivers/staging/greybus/es1-ap-usb.c
drivers/staging/greybus/es1-ap-usb.c
+34
-5
No files found.
drivers/staging/greybus/es1-ap-usb.c
View file @
0dad95dc
...
@@ -46,7 +46,8 @@ struct es1_ap_dev {
...
@@ -46,7 +46,8 @@ struct es1_ap_dev {
struct
urb
*
cport_in_urb
[
NUM_CPORT_IN_URB
];
/* CPort IN urbs */
struct
urb
*
cport_in_urb
[
NUM_CPORT_IN_URB
];
/* CPort IN urbs */
u8
*
cport_in_buffer
[
NUM_CPORT_IN_URB
];
/* CPort IN buffers */
u8
*
cport_in_buffer
[
NUM_CPORT_IN_URB
];
/* CPort IN buffers */
struct
urb
*
cport_out_urb
[
NUM_CPORT_OUT_URB
];
/* CPort OUT urbs */
struct
urb
*
cport_out_urb
[
NUM_CPORT_OUT_URB
];
/* CPort OUT urbs */
u8
cport_out_urb_busy
[
NUM_CPORT_OUT_URB
];
/* CPort OUT urb busy marker */
bool
cport_out_urb_busy
[
NUM_CPORT_OUT_URB
];
/* CPort OUT urb busy marker */
spinlock_t
cport_out_urb_lock
;
/* locks list of cport out urbs */
};
};
static
inline
struct
es1_ap_dev
*
hd_to_es1
(
struct
greybus_host_device
*
hd
)
static
inline
struct
es1_ap_dev
*
hd_to_es1
(
struct
greybus_host_device
*
hd
)
...
@@ -125,10 +126,37 @@ static int send_svc_msg(struct svc_msg *svc_msg, struct greybus_host_device *hd)
...
@@ -125,10 +126,37 @@ static int send_svc_msg(struct svc_msg *svc_msg, struct greybus_host_device *hd)
return
0
;
return
0
;
}
}
static
struct
urb
*
next_free_urb
(
struct
es1_ap_dev
*
es1
)
static
struct
urb
*
next_free_urb
(
struct
es1_ap_dev
*
es1
,
gfp_t
gfp_mask
)
{
{
// FIXME
struct
urb
*
urb
=
NULL
;
return
NULL
;
unsigned
long
flags
;
int
i
;
spin_lock_irqsave
(
&
es1
->
cport_out_urb_lock
,
flags
);
/* Look in our pool of allocated urbs first, as that's the "fastest" */
for
(
i
=
0
;
i
<
NUM_CPORT_OUT_URB
;
++
i
)
{
if
(
es1
->
cport_out_urb_busy
[
i
]
==
false
)
{
es1
->
cport_out_urb_busy
[
i
]
=
true
;
urb
=
es1
->
cport_out_urb
[
i
];
break
;
}
}
spin_unlock_irqrestore
(
&
es1
->
cport_out_urb_lock
,
flags
);
if
(
urb
)
return
urb
;
/*
* Crap, pool is empty, complain to the syslog and go allocate one
* dynamically as we have to succeed.
*/
dev_err
(
&
es1
->
usb_dev
->
dev
,
"No free CPort OUT urbs, having to dynamically allocate one!
\n
"
);
urb
=
usb_alloc_urb
(
0
,
gfp_mask
);
if
(
!
urb
)
return
NULL
;
return
urb
;
}
}
static
int
send_gbuf
(
struct
gbuf
*
gbuf
,
struct
greybus_host_device
*
hd
,
static
int
send_gbuf
(
struct
gbuf
*
gbuf
,
struct
greybus_host_device
*
hd
,
...
@@ -145,7 +173,7 @@ static int send_gbuf(struct gbuf *gbuf, struct greybus_host_device *hd,
...
@@ -145,7 +173,7 @@ static int send_gbuf(struct gbuf *gbuf, struct greybus_host_device *hd,
buffer
=
&
transfer_buffer
[
-
1
];
/* yes, we mean -1 */
buffer
=
&
transfer_buffer
[
-
1
];
/* yes, we mean -1 */
/* Find a free urb */
/* Find a free urb */
urb
=
next_free_urb
(
es1
);
urb
=
next_free_urb
(
es1
,
gfp_mask
);
if
(
!
urb
)
if
(
!
urb
)
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -289,6 +317,7 @@ static int ap_probe(struct usb_interface *interface,
...
@@ -289,6 +317,7 @@ static int ap_probe(struct usb_interface *interface,
es1
->
hd
=
hd
;
es1
->
hd
=
hd
;
es1
->
usb_intf
=
interface
;
es1
->
usb_intf
=
interface
;
es1
->
usb_dev
=
udev
;
es1
->
usb_dev
=
udev
;
spin_lock_init
(
&
es1
->
cport_out_urb_lock
);
usb_set_intfdata
(
interface
,
es1
);
usb_set_intfdata
(
interface
,
es1
);
/* Control endpoint is the pipe to talk to this AP, so save it off */
/* Control endpoint is the pipe to talk to this AP, so save it off */
...
...
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