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
nexedi
linux
Commits
a25f375c
Commit
a25f375c
authored
Oct 28, 2014
by
Greg Kroah-Hartman
Browse files
Options
Browse Files
Download
Plain Diff
greybus: Merge branch 'master' into driver_model_rework
parents
708971e4
a2f4763f
Changes
13
Show whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
118 additions
and
155 deletions
+118
-155
drivers/staging/greybus/battery-gb.c
drivers/staging/greybus/battery-gb.c
+6
-28
drivers/staging/greybus/connection.c
drivers/staging/greybus/connection.c
+12
-26
drivers/staging/greybus/connection.h
drivers/staging/greybus/connection.h
+11
-0
drivers/staging/greybus/core.c
drivers/staging/greybus/core.c
+0
-10
drivers/staging/greybus/gpio-gb.c
drivers/staging/greybus/gpio-gb.c
+7
-3
drivers/staging/greybus/greybus.h
drivers/staging/greybus/greybus.h
+7
-11
drivers/staging/greybus/i2c-gb.c
drivers/staging/greybus/i2c-gb.c
+12
-15
drivers/staging/greybus/interface.c
drivers/staging/greybus/interface.c
+1
-1
drivers/staging/greybus/kernel_ver.h
drivers/staging/greybus/kernel_ver.h
+15
-0
drivers/staging/greybus/module.c
drivers/staging/greybus/module.c
+1
-1
drivers/staging/greybus/operation.c
drivers/staging/greybus/operation.c
+1
-1
drivers/staging/greybus/sdio-gb.c
drivers/staging/greybus/sdio-gb.c
+12
-19
drivers/staging/greybus/uart-gb.c
drivers/staging/greybus/uart-gb.c
+33
-40
No files found.
drivers/staging/greybus/battery-gb.c
View file @
a25f375c
...
@@ -359,7 +359,7 @@ static enum power_supply_property battery_props[] = {
...
@@ -359,7 +359,7 @@ static enum power_supply_property battery_props[] = {
POWER_SUPPLY_PROP_VOLTAGE_NOW
,
POWER_SUPPLY_PROP_VOLTAGE_NOW
,
};
};
int
gb_battery_device
_init
(
struct
gb_connection
*
connection
)
static
int
gb_battery_connection
_init
(
struct
gb_connection
*
connection
)
{
{
struct
gb_battery
*
gb
;
struct
gb_battery
*
gb
;
struct
power_supply
*
b
;
struct
power_supply
*
b
;
...
@@ -369,7 +369,7 @@ int gb_battery_device_init(struct gb_connection *connection)
...
@@ -369,7 +369,7 @@ int gb_battery_device_init(struct gb_connection *connection)
if
(
!
gb
)
if
(
!
gb
)
return
-
ENOMEM
;
return
-
ENOMEM
;
gb
->
connection
=
connection
;
// FIXME refcount!
gb
->
connection
=
connection
;
connection
->
private
=
gb
;
connection
->
private
=
gb
;
/* Check the version */
/* Check the version */
...
@@ -397,7 +397,7 @@ int gb_battery_device_init(struct gb_connection *connection)
...
@@ -397,7 +397,7 @@ int gb_battery_device_init(struct gb_connection *connection)
return
0
;
return
0
;
}
}
void
gb_battery_device
_exit
(
struct
gb_connection
*
connection
)
static
void
gb_battery_connection
_exit
(
struct
gb_connection
*
connection
)
{
{
struct
gb_battery
*
gb
=
connection
->
private
;
struct
gb_battery
*
gb
=
connection
->
private
;
...
@@ -405,29 +405,7 @@ void gb_battery_device_exit(struct gb_connection *connection)
...
@@ -405,29 +405,7 @@ void gb_battery_device_exit(struct gb_connection *connection)
kfree
(
gb
);
kfree
(
gb
);
}
}
void
gb_battery_disconnect
(
struct
gb_module
*
gmod
)
struct
gb_connection_handler
gb_battery_connection_handler
=
{
{
.
connection_init
=
gb_battery_connection_init
,
#if 0
.
connection_exit
=
gb_battery_connection_exit
,
struct gb_battery *gb;
gb = gmod->gb_battery;
if (!gb)
return;
power_supply_unregister(&gb->bat);
kfree(gb);
#endif
}
#if 0
static struct greybus_driver battery_gb_driver = {
.probe = gb_battery_probe,
.disconnect = gb_battery_disconnect,
.id_table = id_table,
};
};
module_greybus_driver(battery_gb_driver);
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Greg Kroah-Hartman <gregkh@linuxfoundation.org>");
#endif
drivers/staging/greybus/connection.c
View file @
a25f375c
...
@@ -170,7 +170,7 @@ struct gb_connection *gb_connection_create(struct gb_interface *interface,
...
@@ -170,7 +170,7 @@ struct gb_connection *gb_connection_create(struct gb_interface *interface,
return
NULL
;
return
NULL
;
}
}
connection
->
interface
=
interface
;
/* XXX refcount? */
connection
->
interface
=
interface
;
connection
->
interface_cport_id
=
cport_id
;
connection
->
interface_cport_id
=
cport_id
;
connection
->
protocol
=
protocol
;
connection
->
protocol
=
protocol
;
connection
->
state
=
GB_CONNECTION_STATE_DISABLED
;
connection
->
state
=
GB_CONNECTION_STATE_DISABLED
;
...
@@ -267,17 +267,19 @@ int gb_connection_init(struct gb_connection *connection)
...
@@ -267,17 +267,19 @@ int gb_connection_init(struct gb_connection *connection)
connection
->
state
=
GB_CONNECTION_STATE_ENABLED
;
connection
->
state
=
GB_CONNECTION_STATE_ENABLED
;
switch
(
connection
->
protocol
)
{
switch
(
connection
->
protocol
)
{
case
GREYBUS_PROTOCOL_I2C
:
case
GREYBUS_PROTOCOL_I2C
:
ret
=
gb_i2c_device_init
(
connection
)
;
connection
->
handler
=
&
gb_i2c_connection_handler
;
break
;
break
;
case
GREYBUS_PROTOCOL_GPIO
:
case
GREYBUS_PROTOCOL_GPIO
:
ret
=
gb_gpio_controller_init
(
connection
)
;
connection
->
handler
=
&
gb_gpio_connection_handler
;
break
;
break
;
case
GREYBUS_PROTOCOL_BATTERY
:
case
GREYBUS_PROTOCOL_BATTERY
:
ret
=
gb_battery_device_init
(
connection
);
connection
->
handler
=
&
gb_battery_connection_handler
;
break
;
case
GREYBUS_PROTOCOL_UART
:
connection
->
handler
=
&
gb_uart_connection_handler
;
break
;
break
;
case
GREYBUS_PROTOCOL_CONTROL
:
case
GREYBUS_PROTOCOL_CONTROL
:
case
GREYBUS_PROTOCOL_AP
:
case
GREYBUS_PROTOCOL_AP
:
case
GREYBUS_PROTOCOL_UART
:
case
GREYBUS_PROTOCOL_HID
:
case
GREYBUS_PROTOCOL_HID
:
case
GREYBUS_PROTOCOL_LED
:
case
GREYBUS_PROTOCOL_LED
:
case
GREYBUS_PROTOCOL_VENDOR
:
case
GREYBUS_PROTOCOL_VENDOR
:
...
@@ -296,26 +298,10 @@ int gb_connection_init(struct gb_connection *connection)
...
@@ -296,26 +298,10 @@ int gb_connection_init(struct gb_connection *connection)
void
gb_connection_exit
(
struct
gb_connection
*
connection
)
void
gb_connection_exit
(
struct
gb_connection
*
connection
)
{
{
connection
->
state
=
GB_CONNECTION_STATE_DESTROYING
;
if
(
!
connection
->
handler
)
{
gb_connection_err
(
connection
,
"uninitialized connection"
);
switch
(
connection
->
protocol
)
{
return
;
case
GREYBUS_PROTOCOL_I2C
:
gb_i2c_device_exit
(
connection
);
break
;
case
GREYBUS_PROTOCOL_GPIO
:
gb_gpio_controller_exit
(
connection
);
break
;
case
GREYBUS_PROTOCOL_BATTERY
:
gb_battery_device_exit
(
connection
);
break
;
case
GREYBUS_PROTOCOL_CONTROL
:
case
GREYBUS_PROTOCOL_AP
:
case
GREYBUS_PROTOCOL_UART
:
case
GREYBUS_PROTOCOL_HID
:
case
GREYBUS_PROTOCOL_VENDOR
:
default:
gb_connection_err
(
connection
,
"unimplemented protocol %u"
,
(
u32
)
connection
->
protocol
);
break
;
}
}
connection
->
state
=
GB_CONNECTION_STATE_DESTROYING
;
connection
->
handler
->
connection_exit
(
connection
);
}
}
drivers/staging/greybus/connection.h
View file @
a25f375c
...
@@ -21,6 +21,15 @@ enum gb_connection_state {
...
@@ -21,6 +21,15 @@ enum gb_connection_state {
GB_CONNECTION_STATE_DESTROYING
=
4
,
GB_CONNECTION_STATE_DESTROYING
=
4
,
};
};
struct
gb_connection
;
typedef
int
(
*
gb_connection_init_t
)(
struct
gb_connection
*
);
typedef
void
(
*
gb_connection_exit_t
)(
struct
gb_connection
*
);
struct
gb_connection_handler
{
gb_connection_init_t
connection_init
;
gb_connection_exit_t
connection_exit
;
};
struct
gb_connection
{
struct
gb_connection
{
struct
greybus_host_device
*
hd
;
struct
greybus_host_device
*
hd
;
struct
gb_interface
*
interface
;
struct
gb_interface
*
interface
;
...
@@ -37,6 +46,8 @@ struct gb_connection {
...
@@ -37,6 +46,8 @@ struct gb_connection {
struct
rb_root
pending
;
/* awaiting reponse */
struct
rb_root
pending
;
/* awaiting reponse */
atomic_t
op_cycle
;
atomic_t
op_cycle
;
struct
gb_connection_handler
*
handler
;
void
*
private
;
void
*
private
;
};
};
#define to_gb_connection(d) container_of(d, struct gb_connection, dev)
#define to_gb_connection(d) container_of(d, struct gb_connection, dev)
...
...
drivers/staging/greybus/core.c
View file @
a25f375c
...
@@ -282,17 +282,8 @@ static int __init gb_init(void)
...
@@ -282,17 +282,8 @@ static int __init gb_init(void)
goto
error_operation
;
goto
error_operation
;
}
}
retval
=
gb_tty_init
();
if
(
retval
)
{
pr_err
(
"gb_tty_init failed
\n
"
);
goto
error_tty
;
}
return
0
;
return
0
;
error_tty:
gb_operation_exit
();
error_operation:
error_operation:
gb_gbuf_exit
();
gb_gbuf_exit
();
...
@@ -310,7 +301,6 @@ static int __init gb_init(void)
...
@@ -310,7 +301,6 @@ static int __init gb_init(void)
static
void
__exit
gb_exit
(
void
)
static
void
__exit
gb_exit
(
void
)
{
{
gb_tty_exit
();
gb_operation_exit
();
gb_operation_exit
();
gb_gbuf_exit
();
gb_gbuf_exit
();
gb_ap_exit
();
gb_ap_exit
();
...
...
drivers/staging/greybus/gpio-gb.c
View file @
a25f375c
...
@@ -29,7 +29,6 @@ struct gb_gpio_controller {
...
@@ -29,7 +29,6 @@ struct gb_gpio_controller {
struct
gb_gpio_line
*
lines
;
struct
gb_gpio_line
*
lines
;
struct
gpio_chip
chip
;
struct
gpio_chip
chip
;
struct
gpio_chip
*
gpio
;
};
};
#define gpio_chip_to_gb_gpio_controller(chip) \
#define gpio_chip_to_gb_gpio_controller(chip) \
container_of(chip, struct gb_gpio_controller, chip)
container_of(chip, struct gb_gpio_controller, chip)
...
@@ -733,7 +732,7 @@ static int gb_gpio_controller_setup(struct gb_gpio_controller *gb_gpio_controlle
...
@@ -733,7 +732,7 @@ static int gb_gpio_controller_setup(struct gb_gpio_controller *gb_gpio_controlle
return
ret
;
return
ret
;
}
}
int
gb_gpio_controller
_init
(
struct
gb_connection
*
connection
)
static
int
gb_gpio_connection
_init
(
struct
gb_connection
*
connection
)
{
{
struct
gb_gpio_controller
*
gb_gpio_controller
;
struct
gb_gpio_controller
*
gb_gpio_controller
;
struct
gpio_chip
*
gpio
;
struct
gpio_chip
*
gpio
;
...
@@ -781,7 +780,7 @@ int gb_gpio_controller_init(struct gb_connection *connection)
...
@@ -781,7 +780,7 @@ int gb_gpio_controller_init(struct gb_connection *connection)
return
ret
;
return
ret
;
}
}
void
gb_gpio_controller
_exit
(
struct
gb_connection
*
connection
)
static
void
gb_gpio_connection
_exit
(
struct
gb_connection
*
connection
)
{
{
struct
gb_gpio_controller
*
gb_gpio_controller
=
connection
->
private
;
struct
gb_gpio_controller
*
gb_gpio_controller
=
connection
->
private
;
...
@@ -793,6 +792,11 @@ void gb_gpio_controller_exit(struct gb_connection *connection)
...
@@ -793,6 +792,11 @@ void gb_gpio_controller_exit(struct gb_connection *connection)
kfree
(
gb_gpio_controller
);
kfree
(
gb_gpio_controller
);
}
}
struct
gb_connection_handler
gb_gpio_connection_handler
=
{
.
connection_init
=
gb_gpio_connection_init
,
.
connection_exit
=
gb_gpio_connection_exit
,
};
#if 0
#if 0
MODULE_LICENSE("GPL");
MODULE_LICENSE("GPL");
MODULE_DESCRIPTION("Greybus GPIO driver");
MODULE_DESCRIPTION("Greybus GPIO driver");
...
...
drivers/staging/greybus/greybus.h
View file @
a25f375c
...
@@ -151,7 +151,6 @@ struct gbuf {
...
@@ -151,7 +151,6 @@ struct gbuf {
struct
gb_i2c_device
;
struct
gb_i2c_device
;
struct
gb_gpio_device
;
struct
gb_gpio_device
;
struct
gb_sdio_host
;
struct
gb_tty
;
struct
gb_tty
;
struct
gb_usb_device
;
struct
gb_usb_device
;
struct
gb_battery
;
struct
gb_battery
;
...
@@ -266,17 +265,14 @@ void gb_deregister_cport_complete(u16 cport_id);
...
@@ -266,17 +265,14 @@ void gb_deregister_cport_complete(u16 cport_id);
extern
struct
bus_type
greybus_bus_type
;
extern
struct
bus_type
greybus_bus_type
;
extern
const
struct
attribute_group
*
greybus_module_groups
[];
extern
const
struct
attribute_group
*
greybus_module_groups
[];
int
gb_i2c_device_init
(
struct
gb_connection
*
connection
);
extern
struct
gb_connection_handler
gb_i2c_connection_handler
;
void
gb_i2c_device_exit
(
struct
gb_connection
*
connection
);
extern
struct
gb_connection_handler
gb_gpio_connection_handler
;
extern
struct
gb_connection_handler
gb_battery_connection_handler
;
extern
struct
gb_connection_handler
gb_uart_connection_handler
;
extern
struct
gb_connection_handler
gb_sdio_connection_handler
;
int
gb_battery_device_init
(
struct
gb_connection
*
connection
);
int
gb_uart_device_init
(
struct
gb_connection
*
connection
);
void
gb_battery_device_exit
(
struct
gb_connection
*
connection
);
void
gb_uart_device_exit
(
struct
gb_connection
*
connection
);
int
gb_gpio_controller_init
(
struct
gb_connection
*
connection
);
void
gb_gpio_controller_exit
(
struct
gb_connection
*
connection
);
int
gb_tty_init
(
void
);
void
gb_tty_exit
(
void
);
int
svc_set_route_send
(
struct
gb_interface
*
interface
,
int
svc_set_route_send
(
struct
gb_interface
*
interface
,
struct
greybus_host_device
*
hd
);
struct
greybus_host_device
*
hd
);
...
...
drivers/staging/greybus/i2c-gb.c
View file @
a25f375c
...
@@ -22,7 +22,7 @@ struct gb_i2c_device {
...
@@ -22,7 +22,7 @@ struct gb_i2c_device {
u16
timeout_msec
;
u16
timeout_msec
;
u8
retries
;
u8
retries
;
struct
i2c_adapter
*
adapter
;
struct
i2c_adapter
adapter
;
};
};
/* Version of the Greybus i2c protocol we support */
/* Version of the Greybus i2c protocol we support */
...
@@ -466,10 +466,10 @@ static int gb_i2c_device_setup(struct gb_i2c_device *gb_i2c_dev)
...
@@ -466,10 +466,10 @@ static int gb_i2c_device_setup(struct gb_i2c_device *gb_i2c_dev)
return
gb_i2c_timeout_operation
(
gb_i2c_dev
,
GB_I2C_TIMEOUT_DEFAULT
);
return
gb_i2c_timeout_operation
(
gb_i2c_dev
,
GB_I2C_TIMEOUT_DEFAULT
);
}
}
int
gb_i2c_device
_init
(
struct
gb_connection
*
connection
)
static
int
gb_i2c_connection
_init
(
struct
gb_connection
*
connection
)
{
{
struct
gb_i2c_device
*
gb_i2c_dev
;
struct
gb_i2c_device
*
gb_i2c_dev
;
struct
i2c_adapter
*
adapter
=
NULL
;
struct
i2c_adapter
*
adapter
;
int
ret
;
int
ret
;
gb_i2c_dev
=
kzalloc
(
sizeof
(
*
gb_i2c_dev
),
GFP_KERNEL
);
gb_i2c_dev
=
kzalloc
(
sizeof
(
*
gb_i2c_dev
),
GFP_KERNEL
);
...
@@ -482,13 +482,8 @@ int gb_i2c_device_init(struct gb_connection *connection)
...
@@ -482,13 +482,8 @@ int gb_i2c_device_init(struct gb_connection *connection)
if
(
ret
)
if
(
ret
)
goto
out_err
;
goto
out_err
;
/* Looks good; allocate and set up our i2c adapter */
/* Looks good; up our i2c adapter */
adapter
=
kzalloc
(
sizeof
(
*
adapter
),
GFP_KERNEL
);
adapter
=
&
gb_i2c_dev
->
adapter
;
if
(
!
adapter
)
{
ret
=
-
ENOMEM
;
goto
out_err
;
}
adapter
->
owner
=
THIS_MODULE
;
adapter
->
owner
=
THIS_MODULE
;
adapter
->
class
=
I2C_CLASS_HWMON
|
I2C_CLASS_SPD
;
adapter
->
class
=
I2C_CLASS_HWMON
|
I2C_CLASS_SPD
;
adapter
->
algo
=
&
gb_i2c_algorithm
;
adapter
->
algo
=
&
gb_i2c_algorithm
;
...
@@ -504,28 +499,30 @@ int gb_i2c_device_init(struct gb_connection *connection)
...
@@ -504,28 +499,30 @@ int gb_i2c_device_init(struct gb_connection *connection)
if
(
ret
)
if
(
ret
)
goto
out_err
;
goto
out_err
;
gb_i2c_dev
->
adapter
=
adapter
;
connection
->
private
=
gb_i2c_dev
;
connection
->
private
=
gb_i2c_dev
;
return
0
;
return
0
;
out_err:
out_err:
kfree
(
adapter
);
/* kref_put(gb_i2c_dev->connection) */
/* kref_put(gb_i2c_dev->connection) */
kfree
(
gb_i2c_dev
);
kfree
(
gb_i2c_dev
);
return
ret
;
return
ret
;
}
}
void
gb_i2c_device
_exit
(
struct
gb_connection
*
connection
)
static
void
gb_i2c_connection
_exit
(
struct
gb_connection
*
connection
)
{
{
struct
gb_i2c_device
*
gb_i2c_dev
=
connection
->
private
;
struct
gb_i2c_device
*
gb_i2c_dev
=
connection
->
private
;
i2c_del_adapter
(
gb_i2c_dev
->
adapter
);
i2c_del_adapter
(
&
gb_i2c_dev
->
adapter
);
kfree
(
gb_i2c_dev
->
adapter
);
/* kref_put(gb_i2c_dev->connection) */
/* kref_put(gb_i2c_dev->connection) */
kfree
(
gb_i2c_dev
);
kfree
(
gb_i2c_dev
);
}
}
struct
gb_connection_handler
gb_i2c_connection_handler
=
{
.
connection_init
=
gb_i2c_connection_init
,
.
connection_exit
=
gb_i2c_connection_exit
,
};
#if 0
#if 0
module_greybus_driver(i2c_gb_driver);
module_greybus_driver(i2c_gb_driver);
MODULE_LICENSE("GPL");
MODULE_LICENSE("GPL");
...
...
drivers/staging/greybus/interface.c
View file @
a25f375c
...
@@ -61,7 +61,7 @@ gb_interface_create(struct gb_module *gmod, u8 interface_id)
...
@@ -61,7 +61,7 @@ gb_interface_create(struct gb_module *gmod, u8 interface_id)
if
(
!
interface
)
if
(
!
interface
)
return
NULL
;
return
NULL
;
interface
->
gmod
=
gmod
;
/* XXX refcount? */
interface
->
gmod
=
gmod
;
interface
->
id
=
interface_id
;
interface
->
id
=
interface_id
;
interface
->
device_id
=
0xff
;
/* Invalid device id to start with */
interface
->
device_id
=
0xff
;
/* Invalid device id to start with */
INIT_LIST_HEAD
(
&
interface
->
connections
);
INIT_LIST_HEAD
(
&
interface
->
connections
);
...
...
drivers/staging/greybus/kernel_ver.h
View file @
a25f375c
...
@@ -48,4 +48,19 @@ static inline void gb_gpiochip_remove(struct gpio_chip *chip)
...
@@ -48,4 +48,19 @@ static inline void gb_gpiochip_remove(struct gpio_chip *chip)
}
}
#endif
#endif
/*
* ATTRIBUTE_GROUPS showed up in 3.11-rc2, but we need to build on 3.10, so add
* it here.
*/
#if LINUX_VERSION_CODE < KERNEL_VERSION(3,11,0)
#define ATTRIBUTE_GROUPS(name) \
static const struct attribute_group name##_group = { \
.attrs = name##_attrs, \
}; \
static const struct attribute_group *name##_groups[] = { \
&name##_group, \
NULL, \
}
#endif
#endif
/* __GREYBUS_KERNEL_VER_H */
#endif
/* __GREYBUS_KERNEL_VER_H */
drivers/staging/greybus/module.c
View file @
a25f375c
...
@@ -82,7 +82,7 @@ struct gb_module *gb_module_create(struct greybus_host_device *hd, u8 module_id)
...
@@ -82,7 +82,7 @@ struct gb_module *gb_module_create(struct greybus_host_device *hd, u8 module_id)
return
NULL
;
return
NULL
;
gmod
->
hd
=
hd
;
/* XXX refcount? */
gmod
->
hd
=
hd
;
/* XXX refcount? */
gmod
->
module_id
=
module_id
;
/* XXX check for dups */
gmod
->
module_id
=
module_id
;
INIT_LIST_HEAD
(
&
gmod
->
interfaces
);
INIT_LIST_HEAD
(
&
gmod
->
interfaces
);
spin_lock_irq
(
&
gb_modules_lock
);
spin_lock_irq
(
&
gb_modules_lock
);
...
...
drivers/staging/greybus/operation.c
View file @
a25f375c
...
@@ -363,7 +363,7 @@ struct gb_operation *gb_operation_create(struct gb_connection *connection,
...
@@ -363,7 +363,7 @@ struct gb_operation *gb_operation_create(struct gb_connection *connection,
operation
=
kmem_cache_zalloc
(
gb_operation_cache
,
gfp_flags
);
operation
=
kmem_cache_zalloc
(
gb_operation_cache
,
gfp_flags
);
if
(
!
operation
)
if
(
!
operation
)
return
NULL
;
return
NULL
;
operation
->
connection
=
connection
;
/* XXX refcount? */
operation
->
connection
=
connection
;
operation
->
request
=
gb_operation_gbuf_create
(
operation
,
type
,
operation
->
request
=
gb_operation_gbuf_create
(
operation
,
type
,
request_size
,
request_size
,
...
...
drivers/staging/greybus/sdio-gb.c
View file @
a25f375c
...
@@ -13,6 +13,7 @@
...
@@ -13,6 +13,7 @@
#include "greybus.h"
#include "greybus.h"
struct
gb_sdio_host
{
struct
gb_sdio_host
{
struct
gb_connection
*
connection
;
struct
mmc_host
*
mmc
;
struct
mmc_host
*
mmc
;
struct
mmc_request
*
mrq
;
struct
mmc_request
*
mrq
;
// FIXME - some lock?
// FIXME - some lock?
...
@@ -45,13 +46,12 @@ static const struct mmc_host_ops gb_sd_ops = {
...
@@ -45,13 +46,12 @@ static const struct mmc_host_ops gb_sd_ops = {
.
get_ro
=
gb_sd_get_ro
,
.
get_ro
=
gb_sd_get_ro
,
};
};
int
gb_sdio_probe
(
struct
gb_module
*
gmod
,
static
int
gb_sdio_connection_init
(
struct
gb_connection
*
connection
)
const
struct
greybus_module_id
*
id
)
{
{
struct
mmc_host
*
mmc
;
struct
mmc_host
*
mmc
;
struct
gb_sdio_host
*
host
;
struct
gb_sdio_host
*
host
;
mmc
=
mmc_alloc_host
(
sizeof
(
struct
gb_sdio_host
),
&
gmod
->
dev
);
mmc
=
mmc_alloc_host
(
sizeof
(
struct
gb_sdio_host
),
&
connection
->
dev
);
if
(
!
mmc
)
if
(
!
mmc
)
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -60,36 +60,29 @@ int gb_sdio_probe(struct gb_module *gmod,
...
@@ -60,36 +60,29 @@ int gb_sdio_probe(struct gb_module *gmod,
mmc
->
ops
=
&
gb_sd_ops
;
mmc
->
ops
=
&
gb_sd_ops
;
// FIXME - set up size limits we can handle.
// FIXME - set up size limits we can handle.
// FIXME - register the host controller.
// gmod->gb_sdio_host = host;
host
->
connection
=
connection
;
connection
->
private
=
host
;
return
0
;
return
0
;
}
}
void
gb_sdio_disconnect
(
struct
gb_module
*
gmod
)
static
void
gb_sdio_connection_exit
(
struct
gb_connection
*
connection
)
{
{
#if 0
struct
mmc_host
*
mmc
;
struct
mmc_host
*
mmc
;
struct
gb_sdio_host
*
host
;
struct
gb_sdio_host
*
host
;
host =
gmod->gb_sdio_host
;
host
=
connection
->
private
;
if
(
!
host
)
if
(
!
host
)
return
;
return
;
mmc
=
host
->
mmc
;
mmc
=
host
->
mmc
;
mmc_remove_host
(
mmc
);
mmc_remove_host
(
mmc
);
mmc_free_host
(
mmc
);
mmc_free_host
(
mmc
);
#endif
connection
->
private
=
NULL
;
}
}
#if 0
struct
gb_connection_handler
gb_sdio_connection_handler
=
{
static struct greybus_driver sd_gb_driver = {
.
connection_init
=
gb_sdio_connection_init
,
.probe = gb_sdio_probe,
.
connection_exit
=
gb_sdio_connection_exit
,
.disconnect = gb_sdio_disconnect,
.id_table = id_table,
};
};
module_greybus_driver(sd_gb_driver);
MODULE_LICENSE("GPL");
MODULE_DESCRIPTION("Greybus SD/MMC Host driver");
MODULE_AUTHOR("Greg Kroah-Hartman <gregkh@linuxfoundation.org>");
#endif
drivers/staging/greybus/uart-gb.c
View file @
a25f375c
...
@@ -35,7 +35,7 @@
...
@@ -35,7 +35,7 @@
struct
gb_tty
{
struct
gb_tty
{
struct
tty_port
port
;
struct
tty_port
port
;
struct
gb_
module
*
gmod
;
struct
gb_
connection
*
connection
;
u16
cport_id
;
u16
cport_id
;
unsigned
int
minor
;
unsigned
int
minor
;
unsigned
char
clocal
;
unsigned
char
clocal
;
...
@@ -59,6 +59,10 @@ static const struct greybus_module_id id_table[] = {
...
@@ -59,6 +59,10 @@ static const struct greybus_module_id id_table[] = {
static
struct
tty_driver
*
gb_tty_driver
;
static
struct
tty_driver
*
gb_tty_driver
;
static
DEFINE_IDR
(
tty_minors
);
static
DEFINE_IDR
(
tty_minors
);
static
DEFINE_MUTEX
(
table_lock
);
static
DEFINE_MUTEX
(
table_lock
);
static
atomic_t
reference_count
=
ATOMIC_INIT
(
0
);
static
int
gb_tty_init
(
void
);
static
void
gb_tty_exit
(
void
);
static
struct
gb_tty
*
get_gb_by_minor
(
unsigned
minor
)
static
struct
gb_tty
*
get_gb_by_minor
(
unsigned
minor
)
{
{
...
@@ -386,14 +390,22 @@ static const struct tty_operations gb_ops = {
...
@@ -386,14 +390,22 @@ static const struct tty_operations gb_ops = {
};
};
int
gb_tty_probe
(
struct
gb_module
*
gmod
,
static
int
gb_uart_connection_init
(
struct
gb_connection
*
connection
)
const
struct
greybus_module_id
*
id
)
{
{
struct
gb_tty
*
gb_tty
;
struct
gb_tty
*
gb_tty
;
struct
device
*
tty_dev
;
struct
device
*
tty_dev
;
int
retval
;
int
retval
;
int
minor
;
int
minor
;
/* First time here, initialize the tty structures */
if
(
atomic_inc_return
(
&
reference_count
)
==
1
)
{
retval
=
gb_tty_init
();
if
(
retval
)
{
atomic_dec
(
&
reference_count
);
return
retval
;
}
}
gb_tty
=
kzalloc
(
sizeof
(
*
gb_tty
),
GFP_KERNEL
);
gb_tty
=
kzalloc
(
sizeof
(
*
gb_tty
),
GFP_KERNEL
);
if
(
!
gb_tty
)
if
(
!
gb_tty
)
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -401,14 +413,14 @@ int gb_tty_probe(struct gb_module *gmod,
...
@@ -401,14 +413,14 @@ int gb_tty_probe(struct gb_module *gmod,
minor
=
alloc_minor
(
gb_tty
);
minor
=
alloc_minor
(
gb_tty
);
if
(
minor
<
0
)
{
if
(
minor
<
0
)
{
if
(
minor
==
-
ENOSPC
)
{
if
(
minor
==
-
ENOSPC
)
{
dev_err
(
&
gmod
->
dev
,
"no more free minor numbers
\n
"
);
dev_err
(
&
connection
->
dev
,
"no more free minor numbers
\n
"
);
return
-
ENODEV
;
return
-
ENODEV
;
}
}
return
minor
;
return
minor
;
}
}
gb_tty
->
minor
=
minor
;
gb_tty
->
minor
=
minor
;
gb_tty
->
gmod
=
gmod
;
gb_tty
->
connection
=
connection
;
spin_lock_init
(
&
gb_tty
->
write_lock
);
spin_lock_init
(
&
gb_tty
->
write_lock
);
spin_lock_init
(
&
gb_tty
->
read_lock
);
spin_lock_init
(
&
gb_tty
->
read_lock
);
init_waitqueue_head
(
&
gb_tty
->
wioctl
);
init_waitqueue_head
(
&
gb_tty
->
wioctl
);
...
@@ -416,10 +428,10 @@ int gb_tty_probe(struct gb_module *gmod,
...
@@ -416,10 +428,10 @@ int gb_tty_probe(struct gb_module *gmod,
/* FIXME - allocate gb buffers */
/* FIXME - allocate gb buffers */
gmod
->
gb_tty
=
gb_tty
;
connection
->
private
=
gb_tty
;
tty_dev
=
tty_port_register_device
(
&
gb_tty
->
port
,
gb_tty_driver
,
minor
,
tty_dev
=
tty_port_register_device
(
&
gb_tty
->
port
,
gb_tty_driver
,
minor
,
&
gmod
->
dev
);
&
connection
->
dev
);
if
(
IS_ERR
(
tty_dev
))
{
if
(
IS_ERR
(
tty_dev
))
{
retval
=
PTR_ERR
(
tty_dev
);
retval
=
PTR_ERR
(
tty_dev
);
goto
error
;
goto
error
;
...
@@ -427,14 +439,14 @@ int gb_tty_probe(struct gb_module *gmod,
...
@@ -427,14 +439,14 @@ int gb_tty_probe(struct gb_module *gmod,
return
0
;
return
0
;
error:
error:
gmod
->
gb_tty
=
NULL
;
connection
->
private
=
NULL
;
release_minor
(
gb_tty
);
release_minor
(
gb_tty
);
return
retval
;
return
retval
;
}
}
void
gb_tty_disconnect
(
struct
gb_module
*
gmod
)
static
void
gb_uart_connection_exit
(
struct
gb_connection
*
connection
)
{
{
struct
gb_tty
*
gb_tty
=
gmod
->
gb_tty
;
struct
gb_tty
*
gb_tty
=
connection
->
private
;
struct
tty_struct
*
tty
;
struct
tty_struct
*
tty
;
if
(
!
gb_tty
)
if
(
!
gb_tty
)
...
@@ -444,7 +456,7 @@ void gb_tty_disconnect(struct gb_module *gmod)
...
@@ -444,7 +456,7 @@ void gb_tty_disconnect(struct gb_module *gmod)
gb_tty
->
disconnected
=
true
;
gb_tty
->
disconnected
=
true
;
wake_up_all
(
&
gb_tty
->
wioctl
);
wake_up_all
(
&
gb_tty
->
wioctl
);
gmod
->
gb_tty
=
NULL
;
connection
->
private
=
NULL
;
mutex_unlock
(
&
gb_tty
->
mutex
);
mutex_unlock
(
&
gb_tty
->
mutex
);
tty
=
tty_port_tty_get
(
&
gb_tty
->
port
);
tty
=
tty_port_tty_get
(
&
gb_tty
->
port
);
...
@@ -461,17 +473,13 @@ void gb_tty_disconnect(struct gb_module *gmod)
...
@@ -461,17 +473,13 @@ void gb_tty_disconnect(struct gb_module *gmod)
tty_port_put
(
&
gb_tty
->
port
);
tty_port_put
(
&
gb_tty
->
port
);
kfree
(
gb_tty
);
kfree
(
gb_tty
);
}
#if 0
/* If last device is gone, tear down the tty structures */
static struct greybus_driver tty_gb_driver = {
if
(
atomic_dec_return
(
&
reference_count
)
==
0
)
.probe = gb_tty_probe,
gb_tty_exit
();
.disconnect = gb_tty_disconnect,
}
.id_table = id_table,
};
#endif
int
__ini
t
gb_tty_init
(
void
)
static
in
t
gb_tty_init
(
void
)
{
{
int
retval
=
0
;
int
retval
=
0
;
...
@@ -499,40 +507,25 @@ int __init gb_tty_init(void)
...
@@ -499,40 +507,25 @@ int __init gb_tty_init(void)
goto
fail_put_gb_tty
;
goto
fail_put_gb_tty
;
}
}
#if 0
retval = greybus_register(&tty_gb_driver);
if (retval) {
pr_err("Can not register greybus driver.\n");
goto fail_unregister_gb_tty;
}
#endif
return
0
;
return
0
;
/* fail_unregister_gb_tty: */
tty_unregister_driver
(
gb_tty_driver
);
fail_put_gb_tty:
fail_put_gb_tty:
put_tty_driver
(
gb_tty_driver
);
put_tty_driver
(
gb_tty_driver
);
fail_unregister_dev:
fail_unregister_dev:
return
retval
;
return
retval
;
}
}
void
__exit
gb_tty_exit
(
void
)
static
void
gb_tty_exit
(
void
)
{
{
int
major
=
MAJOR
(
gb_tty_driver
->
major
);
int
major
=
MAJOR
(
gb_tty_driver
->
major
);
int
minor
=
gb_tty_driver
->
minor_start
;
int
minor
=
gb_tty_driver
->
minor_start
;
#if 0
greybus_deregister(&tty_gb_driver);
#endif
tty_unregister_driver
(
gb_tty_driver
);
tty_unregister_driver
(
gb_tty_driver
);
put_tty_driver
(
gb_tty_driver
);
put_tty_driver
(
gb_tty_driver
);
unregister_chrdev_region
(
MKDEV
(
major
,
minor
),
GB_NUM_MINORS
);
unregister_chrdev_region
(
MKDEV
(
major
,
minor
),
GB_NUM_MINORS
);
}
}
#if 0
struct
gb_connection_handler
gb_uart_connection_handler
=
{
module_init(gb_tty_init);
.
connection_init
=
gb_uart_connection_init
,
module_exit(gb_tty_exit);
.
connection_exit
=
gb_uart_connection_exit
,
MODULE_LICENSE("GPL");
};
MODULE_AUTHOR("Greg Kroah-Hartman <gregkh@linuxfoundation.org>");
#endif
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