x25: Reduce switch/case indent
Make the case labels the same indent as the switch. git diff -w shows 80 column line reflowing. Signed-off-by: Joe Perches <joe@perches.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
89f0e4feaf
commit
fddc5f3e91
5 changed files with 392 additions and 398 deletions
475
net/x25/af_x25.c
475
net/x25/af_x25.c
|
@ -237,21 +237,21 @@ static int x25_device_event(struct notifier_block *this, unsigned long event,
|
||||||
#endif
|
#endif
|
||||||
) {
|
) {
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case NETDEV_UP:
|
case NETDEV_UP:
|
||||||
x25_link_device_up(dev);
|
x25_link_device_up(dev);
|
||||||
break;
|
break;
|
||||||
case NETDEV_GOING_DOWN:
|
case NETDEV_GOING_DOWN:
|
||||||
nb = x25_get_neigh(dev);
|
nb = x25_get_neigh(dev);
|
||||||
if (nb) {
|
if (nb) {
|
||||||
x25_terminate_link(nb);
|
x25_terminate_link(nb);
|
||||||
x25_neigh_put(nb);
|
x25_neigh_put(nb);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case NETDEV_DOWN:
|
case NETDEV_DOWN:
|
||||||
x25_kill_by_device(dev);
|
x25_kill_by_device(dev);
|
||||||
x25_route_device_down(dev);
|
x25_route_device_down(dev);
|
||||||
x25_link_device_down(dev);
|
x25_link_device_down(dev);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1336,256 +1336,253 @@ static int x25_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg)
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case TIOCOUTQ: {
|
case TIOCOUTQ: {
|
||||||
int amount;
|
int amount;
|
||||||
|
|
||||||
amount = sk->sk_sndbuf - sk_wmem_alloc_get(sk);
|
amount = sk->sk_sndbuf - sk_wmem_alloc_get(sk);
|
||||||
if (amount < 0)
|
if (amount < 0)
|
||||||
amount = 0;
|
amount = 0;
|
||||||
rc = put_user(amount, (unsigned int __user *)argp);
|
rc = put_user(amount, (unsigned int __user *)argp);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case TIOCINQ: {
|
case TIOCINQ: {
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
int amount = 0;
|
int amount = 0;
|
||||||
/*
|
/*
|
||||||
* These two are safe on a single CPU system as
|
* These two are safe on a single CPU system as
|
||||||
* only user tasks fiddle here
|
* only user tasks fiddle here
|
||||||
*/
|
*/
|
||||||
lock_sock(sk);
|
lock_sock(sk);
|
||||||
if ((skb = skb_peek(&sk->sk_receive_queue)) != NULL)
|
if ((skb = skb_peek(&sk->sk_receive_queue)) != NULL)
|
||||||
amount = skb->len;
|
amount = skb->len;
|
||||||
release_sock(sk);
|
release_sock(sk);
|
||||||
rc = put_user(amount, (unsigned int __user *)argp);
|
rc = put_user(amount, (unsigned int __user *)argp);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case SIOCGSTAMP:
|
case SIOCGSTAMP:
|
||||||
rc = -EINVAL;
|
rc = -EINVAL;
|
||||||
if (sk)
|
if (sk)
|
||||||
rc = sock_get_timestamp(sk,
|
rc = sock_get_timestamp(sk,
|
||||||
(struct timeval __user *)argp);
|
(struct timeval __user *)argp);
|
||||||
|
break;
|
||||||
|
case SIOCGSTAMPNS:
|
||||||
|
rc = -EINVAL;
|
||||||
|
if (sk)
|
||||||
|
rc = sock_get_timestampns(sk,
|
||||||
|
(struct timespec __user *)argp);
|
||||||
|
break;
|
||||||
|
case SIOCGIFADDR:
|
||||||
|
case SIOCSIFADDR:
|
||||||
|
case SIOCGIFDSTADDR:
|
||||||
|
case SIOCSIFDSTADDR:
|
||||||
|
case SIOCGIFBRDADDR:
|
||||||
|
case SIOCSIFBRDADDR:
|
||||||
|
case SIOCGIFNETMASK:
|
||||||
|
case SIOCSIFNETMASK:
|
||||||
|
case SIOCGIFMETRIC:
|
||||||
|
case SIOCSIFMETRIC:
|
||||||
|
rc = -EINVAL;
|
||||||
|
break;
|
||||||
|
case SIOCADDRT:
|
||||||
|
case SIOCDELRT:
|
||||||
|
rc = -EPERM;
|
||||||
|
if (!capable(CAP_NET_ADMIN))
|
||||||
break;
|
break;
|
||||||
case SIOCGSTAMPNS:
|
rc = x25_route_ioctl(cmd, argp);
|
||||||
rc = -EINVAL;
|
break;
|
||||||
if (sk)
|
case SIOCX25GSUBSCRIP:
|
||||||
rc = sock_get_timestampns(sk,
|
rc = x25_subscr_ioctl(cmd, argp);
|
||||||
(struct timespec __user *)argp);
|
break;
|
||||||
|
case SIOCX25SSUBSCRIP:
|
||||||
|
rc = -EPERM;
|
||||||
|
if (!capable(CAP_NET_ADMIN))
|
||||||
break;
|
break;
|
||||||
case SIOCGIFADDR:
|
rc = x25_subscr_ioctl(cmd, argp);
|
||||||
case SIOCSIFADDR:
|
break;
|
||||||
case SIOCGIFDSTADDR:
|
case SIOCX25GFACILITIES: {
|
||||||
case SIOCSIFDSTADDR:
|
lock_sock(sk);
|
||||||
case SIOCGIFBRDADDR:
|
rc = copy_to_user(argp, &x25->facilities,
|
||||||
case SIOCSIFBRDADDR:
|
sizeof(x25->facilities))
|
||||||
case SIOCGIFNETMASK:
|
? -EFAULT : 0;
|
||||||
case SIOCSIFNETMASK:
|
release_sock(sk);
|
||||||
case SIOCGIFMETRIC:
|
break;
|
||||||
case SIOCSIFMETRIC:
|
}
|
||||||
rc = -EINVAL;
|
|
||||||
break;
|
|
||||||
case SIOCADDRT:
|
|
||||||
case SIOCDELRT:
|
|
||||||
rc = -EPERM;
|
|
||||||
if (!capable(CAP_NET_ADMIN))
|
|
||||||
break;
|
|
||||||
rc = x25_route_ioctl(cmd, argp);
|
|
||||||
break;
|
|
||||||
case SIOCX25GSUBSCRIP:
|
|
||||||
rc = x25_subscr_ioctl(cmd, argp);
|
|
||||||
break;
|
|
||||||
case SIOCX25SSUBSCRIP:
|
|
||||||
rc = -EPERM;
|
|
||||||
if (!capable(CAP_NET_ADMIN))
|
|
||||||
break;
|
|
||||||
rc = x25_subscr_ioctl(cmd, argp);
|
|
||||||
break;
|
|
||||||
case SIOCX25GFACILITIES: {
|
|
||||||
lock_sock(sk);
|
|
||||||
rc = copy_to_user(argp, &x25->facilities,
|
|
||||||
sizeof(x25->facilities))
|
|
||||||
? -EFAULT : 0;
|
|
||||||
release_sock(sk);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case SIOCX25SFACILITIES: {
|
case SIOCX25SFACILITIES: {
|
||||||
struct x25_facilities facilities;
|
struct x25_facilities facilities;
|
||||||
rc = -EFAULT;
|
rc = -EFAULT;
|
||||||
if (copy_from_user(&facilities, argp,
|
if (copy_from_user(&facilities, argp, sizeof(facilities)))
|
||||||
sizeof(facilities)))
|
break;
|
||||||
break;
|
rc = -EINVAL;
|
||||||
rc = -EINVAL;
|
lock_sock(sk);
|
||||||
lock_sock(sk);
|
if (sk->sk_state != TCP_LISTEN &&
|
||||||
if (sk->sk_state != TCP_LISTEN &&
|
sk->sk_state != TCP_CLOSE)
|
||||||
sk->sk_state != TCP_CLOSE)
|
goto out_fac_release;
|
||||||
|
if (facilities.pacsize_in < X25_PS16 ||
|
||||||
|
facilities.pacsize_in > X25_PS4096)
|
||||||
|
goto out_fac_release;
|
||||||
|
if (facilities.pacsize_out < X25_PS16 ||
|
||||||
|
facilities.pacsize_out > X25_PS4096)
|
||||||
|
goto out_fac_release;
|
||||||
|
if (facilities.winsize_in < 1 ||
|
||||||
|
facilities.winsize_in > 127)
|
||||||
|
goto out_fac_release;
|
||||||
|
if (facilities.throughput) {
|
||||||
|
int out = facilities.throughput & 0xf0;
|
||||||
|
int in = facilities.throughput & 0x0f;
|
||||||
|
if (!out)
|
||||||
|
facilities.throughput |=
|
||||||
|
X25_DEFAULT_THROUGHPUT << 4;
|
||||||
|
else if (out < 0x30 || out > 0xD0)
|
||||||
goto out_fac_release;
|
goto out_fac_release;
|
||||||
if (facilities.pacsize_in < X25_PS16 ||
|
if (!in)
|
||||||
facilities.pacsize_in > X25_PS4096)
|
facilities.throughput |=
|
||||||
|
X25_DEFAULT_THROUGHPUT;
|
||||||
|
else if (in < 0x03 || in > 0x0D)
|
||||||
goto out_fac_release;
|
goto out_fac_release;
|
||||||
if (facilities.pacsize_out < X25_PS16 ||
|
}
|
||||||
facilities.pacsize_out > X25_PS4096)
|
if (facilities.reverse &&
|
||||||
goto out_fac_release;
|
(facilities.reverse & 0x81) != 0x81)
|
||||||
if (facilities.winsize_in < 1 ||
|
goto out_fac_release;
|
||||||
facilities.winsize_in > 127)
|
x25->facilities = facilities;
|
||||||
goto out_fac_release;
|
rc = 0;
|
||||||
if (facilities.throughput) {
|
|
||||||
int out = facilities.throughput & 0xf0;
|
|
||||||
int in = facilities.throughput & 0x0f;
|
|
||||||
if (!out)
|
|
||||||
facilities.throughput |=
|
|
||||||
X25_DEFAULT_THROUGHPUT << 4;
|
|
||||||
else if (out < 0x30 || out > 0xD0)
|
|
||||||
goto out_fac_release;
|
|
||||||
if (!in)
|
|
||||||
facilities.throughput |=
|
|
||||||
X25_DEFAULT_THROUGHPUT;
|
|
||||||
else if (in < 0x03 || in > 0x0D)
|
|
||||||
goto out_fac_release;
|
|
||||||
}
|
|
||||||
if (facilities.reverse &&
|
|
||||||
(facilities.reverse & 0x81) != 0x81)
|
|
||||||
goto out_fac_release;
|
|
||||||
x25->facilities = facilities;
|
|
||||||
rc = 0;
|
|
||||||
out_fac_release:
|
out_fac_release:
|
||||||
release_sock(sk);
|
release_sock(sk);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case SIOCX25GDTEFACILITIES: {
|
case SIOCX25GDTEFACILITIES: {
|
||||||
lock_sock(sk);
|
lock_sock(sk);
|
||||||
rc = copy_to_user(argp, &x25->dte_facilities,
|
rc = copy_to_user(argp, &x25->dte_facilities,
|
||||||
sizeof(x25->dte_facilities));
|
sizeof(x25->dte_facilities));
|
||||||
release_sock(sk);
|
release_sock(sk);
|
||||||
if (rc)
|
if (rc)
|
||||||
rc = -EFAULT;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case SIOCX25SDTEFACILITIES: {
|
|
||||||
struct x25_dte_facilities dtefacs;
|
|
||||||
rc = -EFAULT;
|
rc = -EFAULT;
|
||||||
if (copy_from_user(&dtefacs, argp, sizeof(dtefacs)))
|
break;
|
||||||
break;
|
}
|
||||||
rc = -EINVAL;
|
|
||||||
lock_sock(sk);
|
case SIOCX25SDTEFACILITIES: {
|
||||||
if (sk->sk_state != TCP_LISTEN &&
|
struct x25_dte_facilities dtefacs;
|
||||||
sk->sk_state != TCP_CLOSE)
|
rc = -EFAULT;
|
||||||
goto out_dtefac_release;
|
if (copy_from_user(&dtefacs, argp, sizeof(dtefacs)))
|
||||||
if (dtefacs.calling_len > X25_MAX_AE_LEN)
|
break;
|
||||||
goto out_dtefac_release;
|
rc = -EINVAL;
|
||||||
if (dtefacs.calling_ae == NULL)
|
lock_sock(sk);
|
||||||
goto out_dtefac_release;
|
if (sk->sk_state != TCP_LISTEN &&
|
||||||
if (dtefacs.called_len > X25_MAX_AE_LEN)
|
sk->sk_state != TCP_CLOSE)
|
||||||
goto out_dtefac_release;
|
goto out_dtefac_release;
|
||||||
if (dtefacs.called_ae == NULL)
|
if (dtefacs.calling_len > X25_MAX_AE_LEN)
|
||||||
goto out_dtefac_release;
|
goto out_dtefac_release;
|
||||||
x25->dte_facilities = dtefacs;
|
if (dtefacs.calling_ae == NULL)
|
||||||
rc = 0;
|
goto out_dtefac_release;
|
||||||
|
if (dtefacs.called_len > X25_MAX_AE_LEN)
|
||||||
|
goto out_dtefac_release;
|
||||||
|
if (dtefacs.called_ae == NULL)
|
||||||
|
goto out_dtefac_release;
|
||||||
|
x25->dte_facilities = dtefacs;
|
||||||
|
rc = 0;
|
||||||
out_dtefac_release:
|
out_dtefac_release:
|
||||||
release_sock(sk);
|
release_sock(sk);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case SIOCX25GCALLUSERDATA: {
|
||||||
|
lock_sock(sk);
|
||||||
|
rc = copy_to_user(argp, &x25->calluserdata,
|
||||||
|
sizeof(x25->calluserdata))
|
||||||
|
? -EFAULT : 0;
|
||||||
|
release_sock(sk);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case SIOCX25SCALLUSERDATA: {
|
||||||
|
struct x25_calluserdata calluserdata;
|
||||||
|
|
||||||
|
rc = -EFAULT;
|
||||||
|
if (copy_from_user(&calluserdata, argp, sizeof(calluserdata)))
|
||||||
break;
|
break;
|
||||||
}
|
rc = -EINVAL;
|
||||||
|
if (calluserdata.cudlength > X25_MAX_CUD_LEN)
|
||||||
case SIOCX25GCALLUSERDATA: {
|
|
||||||
lock_sock(sk);
|
|
||||||
rc = copy_to_user(argp, &x25->calluserdata,
|
|
||||||
sizeof(x25->calluserdata))
|
|
||||||
? -EFAULT : 0;
|
|
||||||
release_sock(sk);
|
|
||||||
break;
|
break;
|
||||||
}
|
lock_sock(sk);
|
||||||
|
x25->calluserdata = calluserdata;
|
||||||
|
release_sock(sk);
|
||||||
|
rc = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case SIOCX25SCALLUSERDATA: {
|
case SIOCX25GCAUSEDIAG: {
|
||||||
struct x25_calluserdata calluserdata;
|
lock_sock(sk);
|
||||||
|
rc = copy_to_user(argp, &x25->causediag, sizeof(x25->causediag))
|
||||||
|
? -EFAULT : 0;
|
||||||
|
release_sock(sk);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
rc = -EFAULT;
|
case SIOCX25SCAUSEDIAG: {
|
||||||
if (copy_from_user(&calluserdata, argp,
|
struct x25_causediag causediag;
|
||||||
sizeof(calluserdata)))
|
rc = -EFAULT;
|
||||||
break;
|
if (copy_from_user(&causediag, argp, sizeof(causediag)))
|
||||||
rc = -EINVAL;
|
|
||||||
if (calluserdata.cudlength > X25_MAX_CUD_LEN)
|
|
||||||
break;
|
|
||||||
lock_sock(sk);
|
|
||||||
x25->calluserdata = calluserdata;
|
|
||||||
release_sock(sk);
|
|
||||||
rc = 0;
|
|
||||||
break;
|
break;
|
||||||
}
|
lock_sock(sk);
|
||||||
|
x25->causediag = causediag;
|
||||||
|
release_sock(sk);
|
||||||
|
rc = 0;
|
||||||
|
break;
|
||||||
|
|
||||||
case SIOCX25GCAUSEDIAG: {
|
}
|
||||||
lock_sock(sk);
|
|
||||||
rc = copy_to_user(argp, &x25->causediag,
|
|
||||||
sizeof(x25->causediag))
|
|
||||||
? -EFAULT : 0;
|
|
||||||
release_sock(sk);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case SIOCX25SCAUSEDIAG: {
|
case SIOCX25SCUDMATCHLEN: {
|
||||||
struct x25_causediag causediag;
|
struct x25_subaddr sub_addr;
|
||||||
rc = -EFAULT;
|
rc = -EINVAL;
|
||||||
if (copy_from_user(&causediag, argp, sizeof(causediag)))
|
lock_sock(sk);
|
||||||
break;
|
if(sk->sk_state != TCP_CLOSE)
|
||||||
lock_sock(sk);
|
goto out_cud_release;
|
||||||
x25->causediag = causediag;
|
rc = -EFAULT;
|
||||||
release_sock(sk);
|
if (copy_from_user(&sub_addr, argp,
|
||||||
rc = 0;
|
sizeof(sub_addr)))
|
||||||
break;
|
goto out_cud_release;
|
||||||
|
rc = -EINVAL;
|
||||||
}
|
if (sub_addr.cudmatchlength > X25_MAX_CUD_LEN)
|
||||||
|
goto out_cud_release;
|
||||||
case SIOCX25SCUDMATCHLEN: {
|
x25->cudmatchlength = sub_addr.cudmatchlength;
|
||||||
struct x25_subaddr sub_addr;
|
rc = 0;
|
||||||
rc = -EINVAL;
|
|
||||||
lock_sock(sk);
|
|
||||||
if(sk->sk_state != TCP_CLOSE)
|
|
||||||
goto out_cud_release;
|
|
||||||
rc = -EFAULT;
|
|
||||||
if (copy_from_user(&sub_addr, argp,
|
|
||||||
sizeof(sub_addr)))
|
|
||||||
goto out_cud_release;
|
|
||||||
rc = -EINVAL;
|
|
||||||
if(sub_addr.cudmatchlength > X25_MAX_CUD_LEN)
|
|
||||||
goto out_cud_release;
|
|
||||||
x25->cudmatchlength = sub_addr.cudmatchlength;
|
|
||||||
rc = 0;
|
|
||||||
out_cud_release:
|
out_cud_release:
|
||||||
release_sock(sk);
|
release_sock(sk);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case SIOCX25CALLACCPTAPPRV: {
|
case SIOCX25CALLACCPTAPPRV: {
|
||||||
rc = -EINVAL;
|
rc = -EINVAL;
|
||||||
lock_sock(sk);
|
lock_sock(sk);
|
||||||
if (sk->sk_state != TCP_CLOSE)
|
if (sk->sk_state != TCP_CLOSE)
|
||||||
break;
|
|
||||||
clear_bit(X25_ACCPT_APPRV_FLAG, &x25->flags);
|
|
||||||
release_sock(sk);
|
|
||||||
rc = 0;
|
|
||||||
break;
|
break;
|
||||||
}
|
clear_bit(X25_ACCPT_APPRV_FLAG, &x25->flags);
|
||||||
|
release_sock(sk);
|
||||||
|
rc = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case SIOCX25SENDCALLACCPT: {
|
case SIOCX25SENDCALLACCPT: {
|
||||||
rc = -EINVAL;
|
rc = -EINVAL;
|
||||||
lock_sock(sk);
|
lock_sock(sk);
|
||||||
if (sk->sk_state != TCP_ESTABLISHED)
|
if (sk->sk_state != TCP_ESTABLISHED)
|
||||||
break;
|
|
||||||
/* must call accptapprv above */
|
|
||||||
if (test_bit(X25_ACCPT_APPRV_FLAG, &x25->flags))
|
|
||||||
break;
|
|
||||||
x25_write_internal(sk, X25_CALL_ACCEPTED);
|
|
||||||
x25->state = X25_STATE_3;
|
|
||||||
release_sock(sk);
|
|
||||||
rc = 0;
|
|
||||||
break;
|
break;
|
||||||
}
|
/* must call accptapprv above */
|
||||||
|
if (test_bit(X25_ACCPT_APPRV_FLAG, &x25->flags))
|
||||||
|
break;
|
||||||
|
x25_write_internal(sk, X25_CALL_ACCEPTED);
|
||||||
|
x25->state = X25_STATE_3;
|
||||||
|
release_sock(sk);
|
||||||
|
rc = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
default:
|
default:
|
||||||
rc = -ENOIOCTLCMD;
|
rc = -ENOIOCTLCMD;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
|
|
|
@ -146,21 +146,21 @@ void x25_establish_link(struct x25_neigh *nb)
|
||||||
unsigned char *ptr;
|
unsigned char *ptr;
|
||||||
|
|
||||||
switch (nb->dev->type) {
|
switch (nb->dev->type) {
|
||||||
case ARPHRD_X25:
|
case ARPHRD_X25:
|
||||||
if ((skb = alloc_skb(1, GFP_ATOMIC)) == NULL) {
|
if ((skb = alloc_skb(1, GFP_ATOMIC)) == NULL) {
|
||||||
printk(KERN_ERR "x25_dev: out of memory\n");
|
printk(KERN_ERR "x25_dev: out of memory\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
ptr = skb_put(skb, 1);
|
ptr = skb_put(skb, 1);
|
||||||
*ptr = X25_IFACE_CONNECT;
|
*ptr = X25_IFACE_CONNECT;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#if defined(CONFIG_LLC) || defined(CONFIG_LLC_MODULE)
|
#if defined(CONFIG_LLC) || defined(CONFIG_LLC_MODULE)
|
||||||
case ARPHRD_ETHER:
|
case ARPHRD_ETHER:
|
||||||
return;
|
return;
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
skb->protocol = htons(ETH_P_X25);
|
skb->protocol = htons(ETH_P_X25);
|
||||||
|
@ -202,19 +202,19 @@ void x25_send_frame(struct sk_buff *skb, struct x25_neigh *nb)
|
||||||
skb_reset_network_header(skb);
|
skb_reset_network_header(skb);
|
||||||
|
|
||||||
switch (nb->dev->type) {
|
switch (nb->dev->type) {
|
||||||
case ARPHRD_X25:
|
case ARPHRD_X25:
|
||||||
dptr = skb_push(skb, 1);
|
dptr = skb_push(skb, 1);
|
||||||
*dptr = X25_IFACE_DATA;
|
*dptr = X25_IFACE_DATA;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#if defined(CONFIG_LLC) || defined(CONFIG_LLC_MODULE)
|
#if defined(CONFIG_LLC) || defined(CONFIG_LLC_MODULE)
|
||||||
case ARPHRD_ETHER:
|
case ARPHRD_ETHER:
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return;
|
return;
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
skb->protocol = htons(ETH_P_X25);
|
skb->protocol = htons(ETH_P_X25);
|
||||||
|
|
112
net/x25/x25_in.c
112
net/x25/x25_in.c
|
@ -94,55 +94,55 @@ static int x25_state1_machine(struct sock *sk, struct sk_buff *skb, int frametyp
|
||||||
struct x25_sock *x25 = x25_sk(sk);
|
struct x25_sock *x25 = x25_sk(sk);
|
||||||
|
|
||||||
switch (frametype) {
|
switch (frametype) {
|
||||||
case X25_CALL_ACCEPTED: {
|
case X25_CALL_ACCEPTED: {
|
||||||
|
|
||||||
x25_stop_timer(sk);
|
x25_stop_timer(sk);
|
||||||
x25->condition = 0x00;
|
x25->condition = 0x00;
|
||||||
x25->vs = 0;
|
x25->vs = 0;
|
||||||
x25->va = 0;
|
x25->va = 0;
|
||||||
x25->vr = 0;
|
x25->vr = 0;
|
||||||
x25->vl = 0;
|
x25->vl = 0;
|
||||||
x25->state = X25_STATE_3;
|
x25->state = X25_STATE_3;
|
||||||
sk->sk_state = TCP_ESTABLISHED;
|
sk->sk_state = TCP_ESTABLISHED;
|
||||||
/*
|
/*
|
||||||
* Parse the data in the frame.
|
* Parse the data in the frame.
|
||||||
*/
|
*/
|
||||||
skb_pull(skb, X25_STD_MIN_LEN);
|
skb_pull(skb, X25_STD_MIN_LEN);
|
||||||
|
|
||||||
len = x25_parse_address_block(skb, &source_addr,
|
len = x25_parse_address_block(skb, &source_addr,
|
||||||
&dest_addr);
|
&dest_addr);
|
||||||
if (len > 0)
|
if (len > 0)
|
||||||
skb_pull(skb, len);
|
skb_pull(skb, len);
|
||||||
else if (len < 0)
|
else if (len < 0)
|
||||||
goto out_clear;
|
goto out_clear;
|
||||||
|
|
||||||
len = x25_parse_facilities(skb, &x25->facilities,
|
len = x25_parse_facilities(skb, &x25->facilities,
|
||||||
&x25->dte_facilities,
|
&x25->dte_facilities,
|
||||||
&x25->vc_facil_mask);
|
&x25->vc_facil_mask);
|
||||||
if (len > 0)
|
if (len > 0)
|
||||||
skb_pull(skb, len);
|
skb_pull(skb, len);
|
||||||
else if (len < 0)
|
else if (len < 0)
|
||||||
goto out_clear;
|
goto out_clear;
|
||||||
/*
|
/*
|
||||||
* Copy any Call User Data.
|
* Copy any Call User Data.
|
||||||
*/
|
*/
|
||||||
if (skb->len > 0) {
|
if (skb->len > 0) {
|
||||||
skb_copy_from_linear_data(skb,
|
skb_copy_from_linear_data(skb,
|
||||||
x25->calluserdata.cuddata,
|
x25->calluserdata.cuddata,
|
||||||
skb->len);
|
skb->len);
|
||||||
x25->calluserdata.cudlength = skb->len;
|
x25->calluserdata.cudlength = skb->len;
|
||||||
}
|
|
||||||
if (!sock_flag(sk, SOCK_DEAD))
|
|
||||||
sk->sk_state_change(sk);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
case X25_CLEAR_REQUEST:
|
if (!sock_flag(sk, SOCK_DEAD))
|
||||||
x25_write_internal(sk, X25_CLEAR_CONFIRMATION);
|
sk->sk_state_change(sk);
|
||||||
x25_disconnect(sk, ECONNREFUSED, skb->data[3], skb->data[4]);
|
break;
|
||||||
break;
|
}
|
||||||
|
case X25_CLEAR_REQUEST:
|
||||||
|
x25_write_internal(sk, X25_CLEAR_CONFIRMATION);
|
||||||
|
x25_disconnect(sk, ECONNREFUSED, skb->data[3], skb->data[4]);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -354,18 +354,18 @@ int x25_process_rx_frame(struct sock *sk, struct sk_buff *skb)
|
||||||
frametype = x25_decode(sk, skb, &ns, &nr, &q, &d, &m);
|
frametype = x25_decode(sk, skb, &ns, &nr, &q, &d, &m);
|
||||||
|
|
||||||
switch (x25->state) {
|
switch (x25->state) {
|
||||||
case X25_STATE_1:
|
case X25_STATE_1:
|
||||||
queued = x25_state1_machine(sk, skb, frametype);
|
queued = x25_state1_machine(sk, skb, frametype);
|
||||||
break;
|
break;
|
||||||
case X25_STATE_2:
|
case X25_STATE_2:
|
||||||
queued = x25_state2_machine(sk, skb, frametype);
|
queued = x25_state2_machine(sk, skb, frametype);
|
||||||
break;
|
break;
|
||||||
case X25_STATE_3:
|
case X25_STATE_3:
|
||||||
queued = x25_state3_machine(sk, skb, frametype, ns, nr, q, d, m);
|
queued = x25_state3_machine(sk, skb, frametype, ns, nr, q, d, m);
|
||||||
break;
|
break;
|
||||||
case X25_STATE_4:
|
case X25_STATE_4:
|
||||||
queued = x25_state4_machine(sk, skb, frametype);
|
queued = x25_state4_machine(sk, skb, frametype);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
x25_kick(sk);
|
x25_kick(sk);
|
||||||
|
|
|
@ -76,30 +76,29 @@ void x25_link_control(struct sk_buff *skb, struct x25_neigh *nb,
|
||||||
int confirm;
|
int confirm;
|
||||||
|
|
||||||
switch (frametype) {
|
switch (frametype) {
|
||||||
case X25_RESTART_REQUEST:
|
case X25_RESTART_REQUEST:
|
||||||
confirm = !x25_t20timer_pending(nb);
|
confirm = !x25_t20timer_pending(nb);
|
||||||
x25_stop_t20timer(nb);
|
x25_stop_t20timer(nb);
|
||||||
nb->state = X25_LINK_STATE_3;
|
nb->state = X25_LINK_STATE_3;
|
||||||
if (confirm)
|
if (confirm)
|
||||||
x25_transmit_restart_confirmation(nb);
|
x25_transmit_restart_confirmation(nb);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case X25_RESTART_CONFIRMATION:
|
case X25_RESTART_CONFIRMATION:
|
||||||
x25_stop_t20timer(nb);
|
x25_stop_t20timer(nb);
|
||||||
nb->state = X25_LINK_STATE_3;
|
nb->state = X25_LINK_STATE_3;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case X25_DIAGNOSTIC:
|
case X25_DIAGNOSTIC:
|
||||||
printk(KERN_WARNING "x25: diagnostic #%d - "
|
printk(KERN_WARNING "x25: diagnostic #%d - %02X %02X %02X\n",
|
||||||
"%02X %02X %02X\n",
|
skb->data[3], skb->data[4],
|
||||||
skb->data[3], skb->data[4],
|
skb->data[5], skb->data[6]);
|
||||||
skb->data[5], skb->data[6]);
|
break;
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
printk(KERN_WARNING "x25: received unknown %02X "
|
printk(KERN_WARNING "x25: received unknown %02X with LCI 000\n",
|
||||||
"with LCI 000\n", frametype);
|
frametype);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nb->state == X25_LINK_STATE_3)
|
if (nb->state == X25_LINK_STATE_3)
|
||||||
|
@ -193,18 +192,18 @@ void x25_transmit_clear_request(struct x25_neigh *nb, unsigned int lci,
|
||||||
void x25_transmit_link(struct sk_buff *skb, struct x25_neigh *nb)
|
void x25_transmit_link(struct sk_buff *skb, struct x25_neigh *nb)
|
||||||
{
|
{
|
||||||
switch (nb->state) {
|
switch (nb->state) {
|
||||||
case X25_LINK_STATE_0:
|
case X25_LINK_STATE_0:
|
||||||
skb_queue_tail(&nb->queue, skb);
|
skb_queue_tail(&nb->queue, skb);
|
||||||
nb->state = X25_LINK_STATE_1;
|
nb->state = X25_LINK_STATE_1;
|
||||||
x25_establish_link(nb);
|
x25_establish_link(nb);
|
||||||
break;
|
break;
|
||||||
case X25_LINK_STATE_1:
|
case X25_LINK_STATE_1:
|
||||||
case X25_LINK_STATE_2:
|
case X25_LINK_STATE_2:
|
||||||
skb_queue_tail(&nb->queue, skb);
|
skb_queue_tail(&nb->queue, skb);
|
||||||
break;
|
break;
|
||||||
case X25_LINK_STATE_3:
|
case X25_LINK_STATE_3:
|
||||||
x25_send_frame(skb, nb);
|
x25_send_frame(skb, nb);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -214,14 +213,14 @@ void x25_transmit_link(struct sk_buff *skb, struct x25_neigh *nb)
|
||||||
void x25_link_established(struct x25_neigh *nb)
|
void x25_link_established(struct x25_neigh *nb)
|
||||||
{
|
{
|
||||||
switch (nb->state) {
|
switch (nb->state) {
|
||||||
case X25_LINK_STATE_0:
|
case X25_LINK_STATE_0:
|
||||||
nb->state = X25_LINK_STATE_2;
|
nb->state = X25_LINK_STATE_2;
|
||||||
break;
|
break;
|
||||||
case X25_LINK_STATE_1:
|
case X25_LINK_STATE_1:
|
||||||
x25_transmit_restart_request(nb);
|
x25_transmit_restart_request(nb);
|
||||||
nb->state = X25_LINK_STATE_2;
|
nb->state = X25_LINK_STATE_2;
|
||||||
x25_start_t20timer(nb);
|
x25_start_t20timer(nb);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -126,32 +126,30 @@ void x25_write_internal(struct sock *sk, int frametype)
|
||||||
* Adjust frame size.
|
* Adjust frame size.
|
||||||
*/
|
*/
|
||||||
switch (frametype) {
|
switch (frametype) {
|
||||||
case X25_CALL_REQUEST:
|
case X25_CALL_REQUEST:
|
||||||
len += 1 + X25_ADDR_LEN + X25_MAX_FAC_LEN +
|
len += 1 + X25_ADDR_LEN + X25_MAX_FAC_LEN + X25_MAX_CUD_LEN;
|
||||||
X25_MAX_CUD_LEN;
|
break;
|
||||||
break;
|
case X25_CALL_ACCEPTED: /* fast sel with no restr on resp */
|
||||||
case X25_CALL_ACCEPTED: /* fast sel with no restr on resp */
|
if (x25->facilities.reverse & 0x80) {
|
||||||
if(x25->facilities.reverse & 0x80) {
|
len += 1 + X25_MAX_FAC_LEN + X25_MAX_CUD_LEN;
|
||||||
len += 1 + X25_MAX_FAC_LEN + X25_MAX_CUD_LEN;
|
} else {
|
||||||
} else {
|
len += 1 + X25_MAX_FAC_LEN;
|
||||||
len += 1 + X25_MAX_FAC_LEN;
|
}
|
||||||
}
|
break;
|
||||||
break;
|
case X25_CLEAR_REQUEST:
|
||||||
case X25_CLEAR_REQUEST:
|
case X25_RESET_REQUEST:
|
||||||
case X25_RESET_REQUEST:
|
len += 2;
|
||||||
len += 2;
|
break;
|
||||||
break;
|
case X25_RR:
|
||||||
case X25_RR:
|
case X25_RNR:
|
||||||
case X25_RNR:
|
case X25_REJ:
|
||||||
case X25_REJ:
|
case X25_CLEAR_CONFIRMATION:
|
||||||
case X25_CLEAR_CONFIRMATION:
|
case X25_INTERRUPT_CONFIRMATION:
|
||||||
case X25_INTERRUPT_CONFIRMATION:
|
case X25_RESET_CONFIRMATION:
|
||||||
case X25_RESET_CONFIRMATION:
|
break;
|
||||||
break;
|
default:
|
||||||
default:
|
printk(KERN_ERR "X.25: invalid frame type %02X\n", frametype);
|
||||||
printk(KERN_ERR "X.25: invalid frame type %02X\n",
|
return;
|
||||||
frametype);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((skb = alloc_skb(len, GFP_ATOMIC)) == NULL)
|
if ((skb = alloc_skb(len, GFP_ATOMIC)) == NULL)
|
||||||
|
@ -276,20 +274,20 @@ int x25_decode(struct sock *sk, struct sk_buff *skb, int *ns, int *nr, int *q,
|
||||||
*ns = *nr = *q = *d = *m = 0;
|
*ns = *nr = *q = *d = *m = 0;
|
||||||
|
|
||||||
switch (frame[2]) {
|
switch (frame[2]) {
|
||||||
case X25_CALL_REQUEST:
|
case X25_CALL_REQUEST:
|
||||||
case X25_CALL_ACCEPTED:
|
case X25_CALL_ACCEPTED:
|
||||||
case X25_CLEAR_REQUEST:
|
case X25_CLEAR_REQUEST:
|
||||||
case X25_CLEAR_CONFIRMATION:
|
case X25_CLEAR_CONFIRMATION:
|
||||||
case X25_INTERRUPT:
|
case X25_INTERRUPT:
|
||||||
case X25_INTERRUPT_CONFIRMATION:
|
case X25_INTERRUPT_CONFIRMATION:
|
||||||
case X25_RESET_REQUEST:
|
case X25_RESET_REQUEST:
|
||||||
case X25_RESET_CONFIRMATION:
|
case X25_RESET_CONFIRMATION:
|
||||||
case X25_RESTART_REQUEST:
|
case X25_RESTART_REQUEST:
|
||||||
case X25_RESTART_CONFIRMATION:
|
case X25_RESTART_CONFIRMATION:
|
||||||
case X25_REGISTRATION_REQUEST:
|
case X25_REGISTRATION_REQUEST:
|
||||||
case X25_REGISTRATION_CONFIRMATION:
|
case X25_REGISTRATION_CONFIRMATION:
|
||||||
case X25_DIAGNOSTIC:
|
case X25_DIAGNOSTIC:
|
||||||
return frame[2];
|
return frame[2];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (x25->neighbour->extended) {
|
if (x25->neighbour->extended) {
|
||||||
|
|
Loading…
Reference in a new issue