aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorGustavo F. Padovan <padovan@profusion.mobi>2011-12-17 15:53:02 -0500
committerGustavo F. Padovan <padovan@profusion.mobi>2011-12-18 14:07:58 -0500
commit6d438e335ce83ff0528415a58632dc6508e4fde1 (patch)
tree79e191a1c9bd02dfde23c2c38b7c211e5a00e14e /net
parent32845eb1242e4c862de8d27c19ae9b3011f89291 (diff)
Bluetooth: Remove work_add and work_del from hci_sysfs
As we run in process context now we don't need worqueue to add e del from sysfs. Acked-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
Diffstat (limited to 'net')
-rw-r--r--net/bluetooth/hci_sysfs.c71
1 files changed, 27 insertions, 44 deletions
diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c
index c3c1ec871d46..db6af705f8f1 100644
--- a/net/bluetooth/hci_sysfs.c
+++ b/net/bluetooth/hci_sysfs.c
@@ -88,11 +88,35 @@ static struct device_type bt_link = {
88 .release = bt_link_release, 88 .release = bt_link_release,
89}; 89};
90 90
91static void add_conn(struct work_struct *work) 91/*
92 * The rfcomm tty device will possibly retain even when conn
93 * is down, and sysfs doesn't support move zombie device,
94 * so we should move the device before conn device is destroyed.
95 */
96static int __match_tty(struct device *dev, void *data)
97{
98 return !strncmp(dev_name(dev), "rfcomm", 6);
99}
100
101void hci_conn_init_sysfs(struct hci_conn *conn)
102{
103 struct hci_dev *hdev = conn->hdev;
104
105 BT_DBG("conn %p", conn);
106
107 conn->dev.type = &bt_link;
108 conn->dev.class = bt_class;
109 conn->dev.parent = &hdev->dev;
110
111 device_initialize(&conn->dev);
112}
113
114void hci_conn_add_sysfs(struct hci_conn *conn)
92{ 115{
93 struct hci_conn *conn = container_of(work, struct hci_conn, work_add);
94 struct hci_dev *hdev = conn->hdev; 116 struct hci_dev *hdev = conn->hdev;
95 117
118 BT_DBG("conn %p", conn);
119
96 dev_set_name(&conn->dev, "%s:%d", hdev->name, conn->handle); 120 dev_set_name(&conn->dev, "%s:%d", hdev->name, conn->handle);
97 121
98 dev_set_drvdata(&conn->dev, conn); 122 dev_set_drvdata(&conn->dev, conn);
@@ -105,19 +129,8 @@ static void add_conn(struct work_struct *work)
105 hci_dev_hold(hdev); 129 hci_dev_hold(hdev);
106} 130}
107 131
108/* 132void hci_conn_del_sysfs(struct hci_conn *conn)
109 * The rfcomm tty device will possibly retain even when conn
110 * is down, and sysfs doesn't support move zombie device,
111 * so we should move the device before conn device is destroyed.
112 */
113static int __match_tty(struct device *dev, void *data)
114{
115 return !strncmp(dev_name(dev), "rfcomm", 6);
116}
117
118static void del_conn(struct work_struct *work)
119{ 133{
120 struct hci_conn *conn = container_of(work, struct hci_conn, work_del);
121 struct hci_dev *hdev = conn->hdev; 134 struct hci_dev *hdev = conn->hdev;
122 135
123 if (!device_is_registered(&conn->dev)) 136 if (!device_is_registered(&conn->dev))
@@ -139,36 +152,6 @@ static void del_conn(struct work_struct *work)
139 hci_dev_put(hdev); 152 hci_dev_put(hdev);
140} 153}
141 154
142void hci_conn_init_sysfs(struct hci_conn *conn)
143{
144 struct hci_dev *hdev = conn->hdev;
145
146 BT_DBG("conn %p", conn);
147
148 conn->dev.type = &bt_link;
149 conn->dev.class = bt_class;
150 conn->dev.parent = &hdev->dev;
151
152 device_initialize(&conn->dev);
153
154 INIT_WORK(&conn->work_add, add_conn);
155 INIT_WORK(&conn->work_del, del_conn);
156}
157
158void hci_conn_add_sysfs(struct hci_conn *conn)
159{
160 BT_DBG("conn %p", conn);
161
162 queue_work(conn->hdev->workqueue, &conn->work_add);
163}
164
165void hci_conn_del_sysfs(struct hci_conn *conn)
166{
167 BT_DBG("conn %p", conn);
168
169 queue_work(conn->hdev->workqueue, &conn->work_del);
170}
171
172static inline char *host_bustostr(int bus) 155static inline char *host_bustostr(int bus)
173{ 156{
174 switch (bus) { 157 switch (bus) {