diff options
| author | Marcel Holtmann <marcel@holtmann.org> | 2007-05-05 00:36:06 +0200 | 
|---|---|---|
| committer | Marcel Holtmann <marcel@holtmann.org> | 2007-05-05 00:36:06 +0200 | 
| commit | 48db9ca4f2ac9f39eb90ccb12ad3ca7b645a552c (patch) | |
| tree | 5e821efe2a51e60d0c195ee87b5782a36bcad15a | |
| parent | 53c1d4b0b22243c093ded25aaa01c8ff8ab6e6b3 (diff) | |
[Bluetooth] Use in-kernel sockets API
The kernel provides a new convenient way to access the sockets API for
in-kernel users. It is a good idea to actually use it.
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
| -rw-r--r-- | net/bluetooth/rfcomm/core.c | 19 | 
1 files changed, 6 insertions, 13 deletions
| diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c index fe7df90eb707..71a72fcb2b54 100644 --- a/net/bluetooth/rfcomm/core.c +++ b/net/bluetooth/rfcomm/core.c @@ -622,7 +622,7 @@ static struct rfcomm_session *rfcomm_session_create(bdaddr_t *src, bdaddr_t *dst  	bacpy(&addr.l2_bdaddr, src);  	addr.l2_family = AF_BLUETOOTH;  	addr.l2_psm    = 0; -	*err = sock->ops->bind(sock, (struct sockaddr *) &addr, sizeof(addr)); +	*err = kernel_bind(sock, (struct sockaddr *) &addr, sizeof(addr));  	if (*err < 0)  		goto failed; @@ -643,7 +643,7 @@ static struct rfcomm_session *rfcomm_session_create(bdaddr_t *src, bdaddr_t *dst  	bacpy(&addr.l2_bdaddr, dst);  	addr.l2_family = AF_BLUETOOTH;  	addr.l2_psm    = htobs(RFCOMM_PSM); -	*err = sock->ops->connect(sock, (struct sockaddr *) &addr, sizeof(addr), O_NONBLOCK); +	*err = kernel_connect(sock, (struct sockaddr *) &addr, sizeof(addr), O_NONBLOCK);  	if (*err == 0 || *err == -EINPROGRESS)  		return s; @@ -1757,19 +1757,12 @@ static inline void rfcomm_accept_connection(struct rfcomm_session *s)  	BT_DBG("session %p", s); -	if (sock_create_lite(PF_BLUETOOTH, sock->type, BTPROTO_L2CAP, &nsock)) +	err = kernel_accept(sock, &nsock, O_NONBLOCK); +	if (err < 0)  		return; -	nsock->ops  = sock->ops; -  	__module_get(nsock->ops->owner); -	err = sock->ops->accept(sock, nsock, O_NONBLOCK); -	if (err < 0) { -		sock_release(nsock); -		return; -	} -  	/* Set our callbacks */  	nsock->sk->sk_data_ready   = rfcomm_l2data_ready;  	nsock->sk->sk_state_change = rfcomm_l2state_change; @@ -1885,7 +1878,7 @@ static int rfcomm_add_listener(bdaddr_t *ba)  	bacpy(&addr.l2_bdaddr, ba);  	addr.l2_family = AF_BLUETOOTH;  	addr.l2_psm    = htobs(RFCOMM_PSM); -	err = sock->ops->bind(sock, (struct sockaddr *) &addr, sizeof(addr)); +	err = kernel_bind(sock, (struct sockaddr *) &addr, sizeof(addr));  	if (err < 0) {  		BT_ERR("Bind failed %d", err);  		goto failed; @@ -1898,7 +1891,7 @@ static int rfcomm_add_listener(bdaddr_t *ba)  	release_sock(sk);  	/* Start listening on the socket */ -	err = sock->ops->listen(sock, 10); +	err = kernel_listen(sock, 10);  	if (err) {  		BT_ERR("Listen failed %d", err);  		goto failed; | 
