diff options
-rw-r--r-- | net/iucv/af_iucv.c | 44 |
1 files changed, 23 insertions, 21 deletions
diff --git a/net/iucv/af_iucv.c b/net/iucv/af_iucv.c index 2270e25a0298..1d8cb72da3a4 100644 --- a/net/iucv/af_iucv.c +++ b/net/iucv/af_iucv.c | |||
@@ -446,23 +446,25 @@ static void iucv_sock_init(struct sock *sk, struct sock *parent) | |||
446 | static struct sock *iucv_sock_alloc(struct socket *sock, int proto, gfp_t prio) | 446 | static struct sock *iucv_sock_alloc(struct socket *sock, int proto, gfp_t prio) |
447 | { | 447 | { |
448 | struct sock *sk; | 448 | struct sock *sk; |
449 | struct iucv_sock *iucv; | ||
449 | 450 | ||
450 | sk = sk_alloc(&init_net, PF_IUCV, prio, &iucv_proto); | 451 | sk = sk_alloc(&init_net, PF_IUCV, prio, &iucv_proto); |
451 | if (!sk) | 452 | if (!sk) |
452 | return NULL; | 453 | return NULL; |
454 | iucv = iucv_sk(sk); | ||
453 | 455 | ||
454 | sock_init_data(sock, sk); | 456 | sock_init_data(sock, sk); |
455 | INIT_LIST_HEAD(&iucv_sk(sk)->accept_q); | 457 | INIT_LIST_HEAD(&iucv->accept_q); |
456 | spin_lock_init(&iucv_sk(sk)->accept_q_lock); | 458 | spin_lock_init(&iucv->accept_q_lock); |
457 | skb_queue_head_init(&iucv_sk(sk)->send_skb_q); | 459 | skb_queue_head_init(&iucv->send_skb_q); |
458 | INIT_LIST_HEAD(&iucv_sk(sk)->message_q.list); | 460 | INIT_LIST_HEAD(&iucv->message_q.list); |
459 | spin_lock_init(&iucv_sk(sk)->message_q.lock); | 461 | spin_lock_init(&iucv->message_q.lock); |
460 | skb_queue_head_init(&iucv_sk(sk)->backlog_skb_q); | 462 | skb_queue_head_init(&iucv->backlog_skb_q); |
461 | iucv_sk(sk)->send_tag = 0; | 463 | iucv->send_tag = 0; |
462 | iucv_sk(sk)->flags = 0; | 464 | iucv->flags = 0; |
463 | iucv_sk(sk)->msglimit = IUCV_QUEUELEN_DEFAULT; | 465 | iucv->msglimit = IUCV_QUEUELEN_DEFAULT; |
464 | iucv_sk(sk)->path = NULL; | 466 | iucv->path = NULL; |
465 | memset(&iucv_sk(sk)->src_user_id , 0, 32); | 467 | memset(&iucv->src_user_id , 0, 32); |
466 | 468 | ||
467 | sk->sk_destruct = iucv_sock_destruct; | 469 | sk->sk_destruct = iucv_sock_destruct; |
468 | sk->sk_sndtimeo = IUCV_CONN_TIMEOUT; | 470 | sk->sk_sndtimeo = IUCV_CONN_TIMEOUT; |
@@ -669,7 +671,7 @@ static int iucv_sock_connect(struct socket *sock, struct sockaddr *addr, | |||
669 | { | 671 | { |
670 | struct sockaddr_iucv *sa = (struct sockaddr_iucv *) addr; | 672 | struct sockaddr_iucv *sa = (struct sockaddr_iucv *) addr; |
671 | struct sock *sk = sock->sk; | 673 | struct sock *sk = sock->sk; |
672 | struct iucv_sock *iucv; | 674 | struct iucv_sock *iucv = iucv_sk(sk); |
673 | unsigned char user_data[16]; | 675 | unsigned char user_data[16]; |
674 | int err; | 676 | int err; |
675 | 677 | ||
@@ -691,14 +693,13 @@ static int iucv_sock_connect(struct socket *sock, struct sockaddr *addr, | |||
691 | lock_sock(sk); | 693 | lock_sock(sk); |
692 | 694 | ||
693 | /* Set the destination information */ | 695 | /* Set the destination information */ |
694 | memcpy(iucv_sk(sk)->dst_user_id, sa->siucv_user_id, 8); | 696 | memcpy(iucv->dst_user_id, sa->siucv_user_id, 8); |
695 | memcpy(iucv_sk(sk)->dst_name, sa->siucv_name, 8); | 697 | memcpy(iucv->dst_name, sa->siucv_name, 8); |
696 | 698 | ||
697 | high_nmcpy(user_data, sa->siucv_name); | 699 | high_nmcpy(user_data, sa->siucv_name); |
698 | low_nmcpy(user_data, iucv_sk(sk)->src_name); | 700 | low_nmcpy(user_data, iucv->src_name); |
699 | ASCEBC(user_data, sizeof(user_data)); | 701 | ASCEBC(user_data, sizeof(user_data)); |
700 | 702 | ||
701 | iucv = iucv_sk(sk); | ||
702 | /* Create path. */ | 703 | /* Create path. */ |
703 | iucv->path = iucv_path_alloc(iucv->msglimit, | 704 | iucv->path = iucv_path_alloc(iucv->msglimit, |
704 | IUCV_IPRMDATA, GFP_KERNEL); | 705 | IUCV_IPRMDATA, GFP_KERNEL); |
@@ -836,20 +837,21 @@ static int iucv_sock_getname(struct socket *sock, struct sockaddr *addr, | |||
836 | { | 837 | { |
837 | struct sockaddr_iucv *siucv = (struct sockaddr_iucv *) addr; | 838 | struct sockaddr_iucv *siucv = (struct sockaddr_iucv *) addr; |
838 | struct sock *sk = sock->sk; | 839 | struct sock *sk = sock->sk; |
840 | struct iucv_sock *iucv = iucv_sk(sk); | ||
839 | 841 | ||
840 | addr->sa_family = AF_IUCV; | 842 | addr->sa_family = AF_IUCV; |
841 | *len = sizeof(struct sockaddr_iucv); | 843 | *len = sizeof(struct sockaddr_iucv); |
842 | 844 | ||
843 | if (peer) { | 845 | if (peer) { |
844 | memcpy(siucv->siucv_user_id, iucv_sk(sk)->dst_user_id, 8); | 846 | memcpy(siucv->siucv_user_id, iucv->dst_user_id, 8); |
845 | memcpy(siucv->siucv_name, &iucv_sk(sk)->dst_name, 8); | 847 | memcpy(siucv->siucv_name, iucv->dst_name, 8); |
846 | } else { | 848 | } else { |
847 | memcpy(siucv->siucv_user_id, iucv_sk(sk)->src_user_id, 8); | 849 | memcpy(siucv->siucv_user_id, iucv->src_user_id, 8); |
848 | memcpy(siucv->siucv_name, iucv_sk(sk)->src_name, 8); | 850 | memcpy(siucv->siucv_name, iucv->src_name, 8); |
849 | } | 851 | } |
850 | memset(&siucv->siucv_port, 0, sizeof(siucv->siucv_port)); | 852 | memset(&siucv->siucv_port, 0, sizeof(siucv->siucv_port)); |
851 | memset(&siucv->siucv_addr, 0, sizeof(siucv->siucv_addr)); | 853 | memset(&siucv->siucv_addr, 0, sizeof(siucv->siucv_addr)); |
852 | memset(siucv->siucv_nodeid, 0, sizeof(siucv->siucv_nodeid)); | 854 | memset(&siucv->siucv_nodeid, 0, sizeof(siucv->siucv_nodeid)); |
853 | 855 | ||
854 | return 0; | 856 | return 0; |
855 | } | 857 | } |