diff options
Diffstat (limited to 'drivers/net/wan/hdlc_fr.c')
-rw-r--r-- | drivers/net/wan/hdlc_fr.c | 96 |
1 files changed, 43 insertions, 53 deletions
diff --git a/drivers/net/wan/hdlc_fr.c b/drivers/net/wan/hdlc_fr.c index fc433f28c047..b25c9229a6a9 100644 --- a/drivers/net/wan/hdlc_fr.c +++ b/drivers/net/wan/hdlc_fr.c | |||
@@ -446,15 +446,14 @@ static netdev_tx_t pvc_xmit(struct sk_buff *skb, struct net_device *dev) | |||
446 | 446 | ||
447 | static inline void fr_log_dlci_active(pvc_device *pvc) | 447 | static inline void fr_log_dlci_active(pvc_device *pvc) |
448 | { | 448 | { |
449 | printk(KERN_INFO "%s: DLCI %d [%s%s%s]%s %s\n", | 449 | netdev_info(pvc->frad, "DLCI %d [%s%s%s]%s %s\n", |
450 | pvc->frad->name, | 450 | pvc->dlci, |
451 | pvc->dlci, | 451 | pvc->main ? pvc->main->name : "", |
452 | pvc->main ? pvc->main->name : "", | 452 | pvc->main && pvc->ether ? " " : "", |
453 | pvc->main && pvc->ether ? " " : "", | 453 | pvc->ether ? pvc->ether->name : "", |
454 | pvc->ether ? pvc->ether->name : "", | 454 | pvc->state.new ? " new" : "", |
455 | pvc->state.new ? " new" : "", | 455 | !pvc->state.exist ? "deleted" : |
456 | !pvc->state.exist ? "deleted" : | 456 | pvc->state.active ? "active" : "inactive"); |
457 | pvc->state.active ? "active" : "inactive"); | ||
458 | } | 457 | } |
459 | 458 | ||
460 | 459 | ||
@@ -481,16 +480,14 @@ static void fr_lmi_send(struct net_device *dev, int fullrep) | |||
481 | if (dce && fullrep) { | 480 | if (dce && fullrep) { |
482 | len += state(hdlc)->dce_pvc_count * (2 + stat_len); | 481 | len += state(hdlc)->dce_pvc_count * (2 + stat_len); |
483 | if (len > HDLC_MAX_MRU) { | 482 | if (len > HDLC_MAX_MRU) { |
484 | printk(KERN_WARNING "%s: Too many PVCs while sending " | 483 | netdev_warn(dev, "Too many PVCs while sending LMI full report\n"); |
485 | "LMI full report\n", dev->name); | ||
486 | return; | 484 | return; |
487 | } | 485 | } |
488 | } | 486 | } |
489 | 487 | ||
490 | skb = dev_alloc_skb(len); | 488 | skb = dev_alloc_skb(len); |
491 | if (!skb) { | 489 | if (!skb) { |
492 | printk(KERN_WARNING "%s: Memory squeeze on fr_lmi_send()\n", | 490 | netdev_warn(dev, "Memory squeeze on fr_lmi_send()\n"); |
493 | dev->name); | ||
494 | return; | 491 | return; |
495 | } | 492 | } |
496 | memset(skb->data, 0, len); | 493 | memset(skb->data, 0, len); |
@@ -615,8 +612,7 @@ static void fr_timer(unsigned long arg) | |||
615 | state(hdlc)->last_errors <<= 1; /* Shift the list */ | 612 | state(hdlc)->last_errors <<= 1; /* Shift the list */ |
616 | if (state(hdlc)->request) { | 613 | if (state(hdlc)->request) { |
617 | if (state(hdlc)->reliable) | 614 | if (state(hdlc)->reliable) |
618 | printk(KERN_INFO "%s: No LMI status reply " | 615 | netdev_info(dev, "No LMI status reply received\n"); |
619 | "received\n", dev->name); | ||
620 | state(hdlc)->last_errors |= 1; | 616 | state(hdlc)->last_errors |= 1; |
621 | } | 617 | } |
622 | 618 | ||
@@ -628,8 +624,7 @@ static void fr_timer(unsigned long arg) | |||
628 | } | 624 | } |
629 | 625 | ||
630 | if (state(hdlc)->reliable != reliable) { | 626 | if (state(hdlc)->reliable != reliable) { |
631 | printk(KERN_INFO "%s: Link %sreliable\n", dev->name, | 627 | netdev_info(dev, "Link %sreliable\n", reliable ? "" : "un"); |
632 | reliable ? "" : "un"); | ||
633 | fr_set_link_state(reliable, dev); | 628 | fr_set_link_state(reliable, dev); |
634 | } | 629 | } |
635 | 630 | ||
@@ -665,33 +660,32 @@ static int fr_lmi_recv(struct net_device *dev, struct sk_buff *skb) | |||
665 | 660 | ||
666 | if (skb->len < (lmi == LMI_ANSI ? LMI_ANSI_LENGTH : | 661 | if (skb->len < (lmi == LMI_ANSI ? LMI_ANSI_LENGTH : |
667 | LMI_CCITT_CISCO_LENGTH)) { | 662 | LMI_CCITT_CISCO_LENGTH)) { |
668 | printk(KERN_INFO "%s: Short LMI frame\n", dev->name); | 663 | netdev_info(dev, "Short LMI frame\n"); |
669 | return 1; | 664 | return 1; |
670 | } | 665 | } |
671 | 666 | ||
672 | if (skb->data[3] != (lmi == LMI_CISCO ? NLPID_CISCO_LMI : | 667 | if (skb->data[3] != (lmi == LMI_CISCO ? NLPID_CISCO_LMI : |
673 | NLPID_CCITT_ANSI_LMI)) { | 668 | NLPID_CCITT_ANSI_LMI)) { |
674 | printk(KERN_INFO "%s: Received non-LMI frame with LMI DLCI\n", | 669 | netdev_info(dev, "Received non-LMI frame with LMI DLCI\n"); |
675 | dev->name); | ||
676 | return 1; | 670 | return 1; |
677 | } | 671 | } |
678 | 672 | ||
679 | if (skb->data[4] != LMI_CALLREF) { | 673 | if (skb->data[4] != LMI_CALLREF) { |
680 | printk(KERN_INFO "%s: Invalid LMI Call reference (0x%02X)\n", | 674 | netdev_info(dev, "Invalid LMI Call reference (0x%02X)\n", |
681 | dev->name, skb->data[4]); | 675 | skb->data[4]); |
682 | return 1; | 676 | return 1; |
683 | } | 677 | } |
684 | 678 | ||
685 | if (skb->data[5] != (dce ? LMI_STATUS_ENQUIRY : LMI_STATUS)) { | 679 | if (skb->data[5] != (dce ? LMI_STATUS_ENQUIRY : LMI_STATUS)) { |
686 | printk(KERN_INFO "%s: Invalid LMI Message type (0x%02X)\n", | 680 | netdev_info(dev, "Invalid LMI Message type (0x%02X)\n", |
687 | dev->name, skb->data[5]); | 681 | skb->data[5]); |
688 | return 1; | 682 | return 1; |
689 | } | 683 | } |
690 | 684 | ||
691 | if (lmi == LMI_ANSI) { | 685 | if (lmi == LMI_ANSI) { |
692 | if (skb->data[6] != LMI_ANSI_LOCKSHIFT) { | 686 | if (skb->data[6] != LMI_ANSI_LOCKSHIFT) { |
693 | printk(KERN_INFO "%s: Not ANSI locking shift in LMI" | 687 | netdev_info(dev, "Not ANSI locking shift in LMI message (0x%02X)\n", |
694 | " message (0x%02X)\n", dev->name, skb->data[6]); | 688 | skb->data[6]); |
695 | return 1; | 689 | return 1; |
696 | } | 690 | } |
697 | i = 7; | 691 | i = 7; |
@@ -700,34 +694,34 @@ static int fr_lmi_recv(struct net_device *dev, struct sk_buff *skb) | |||
700 | 694 | ||
701 | if (skb->data[i] != (lmi == LMI_CCITT ? LMI_CCITT_REPTYPE : | 695 | if (skb->data[i] != (lmi == LMI_CCITT ? LMI_CCITT_REPTYPE : |
702 | LMI_ANSI_CISCO_REPTYPE)) { | 696 | LMI_ANSI_CISCO_REPTYPE)) { |
703 | printk(KERN_INFO "%s: Not an LMI Report type IE (0x%02X)\n", | 697 | netdev_info(dev, "Not an LMI Report type IE (0x%02X)\n", |
704 | dev->name, skb->data[i]); | 698 | skb->data[i]); |
705 | return 1; | 699 | return 1; |
706 | } | 700 | } |
707 | 701 | ||
708 | if (skb->data[++i] != LMI_REPT_LEN) { | 702 | if (skb->data[++i] != LMI_REPT_LEN) { |
709 | printk(KERN_INFO "%s: Invalid LMI Report type IE length" | 703 | netdev_info(dev, "Invalid LMI Report type IE length (%u)\n", |
710 | " (%u)\n", dev->name, skb->data[i]); | 704 | skb->data[i]); |
711 | return 1; | 705 | return 1; |
712 | } | 706 | } |
713 | 707 | ||
714 | reptype = skb->data[++i]; | 708 | reptype = skb->data[++i]; |
715 | if (reptype != LMI_INTEGRITY && reptype != LMI_FULLREP) { | 709 | if (reptype != LMI_INTEGRITY && reptype != LMI_FULLREP) { |
716 | printk(KERN_INFO "%s: Unsupported LMI Report type (0x%02X)\n", | 710 | netdev_info(dev, "Unsupported LMI Report type (0x%02X)\n", |
717 | dev->name, reptype); | 711 | reptype); |
718 | return 1; | 712 | return 1; |
719 | } | 713 | } |
720 | 714 | ||
721 | if (skb->data[++i] != (lmi == LMI_CCITT ? LMI_CCITT_ALIVE : | 715 | if (skb->data[++i] != (lmi == LMI_CCITT ? LMI_CCITT_ALIVE : |
722 | LMI_ANSI_CISCO_ALIVE)) { | 716 | LMI_ANSI_CISCO_ALIVE)) { |
723 | printk(KERN_INFO "%s: Not an LMI Link integrity verification" | 717 | netdev_info(dev, "Not an LMI Link integrity verification IE (0x%02X)\n", |
724 | " IE (0x%02X)\n", dev->name, skb->data[i]); | 718 | skb->data[i]); |
725 | return 1; | 719 | return 1; |
726 | } | 720 | } |
727 | 721 | ||
728 | if (skb->data[++i] != LMI_INTEG_LEN) { | 722 | if (skb->data[++i] != LMI_INTEG_LEN) { |
729 | printk(KERN_INFO "%s: Invalid LMI Link integrity verification" | 723 | netdev_info(dev, "Invalid LMI Link integrity verification IE length (%u)\n", |
730 | " IE length (%u)\n", dev->name, skb->data[i]); | 724 | skb->data[i]); |
731 | return 1; | 725 | return 1; |
732 | } | 726 | } |
733 | i++; | 727 | i++; |
@@ -801,14 +795,14 @@ static int fr_lmi_recv(struct net_device *dev, struct sk_buff *skb) | |||
801 | 795 | ||
802 | if (skb->data[i] != (lmi == LMI_CCITT ? LMI_CCITT_PVCSTAT : | 796 | if (skb->data[i] != (lmi == LMI_CCITT ? LMI_CCITT_PVCSTAT : |
803 | LMI_ANSI_CISCO_PVCSTAT)) { | 797 | LMI_ANSI_CISCO_PVCSTAT)) { |
804 | printk(KERN_INFO "%s: Not an LMI PVC status IE" | 798 | netdev_info(dev, "Not an LMI PVC status IE (0x%02X)\n", |
805 | " (0x%02X)\n", dev->name, skb->data[i]); | 799 | skb->data[i]); |
806 | return 1; | 800 | return 1; |
807 | } | 801 | } |
808 | 802 | ||
809 | if (skb->data[++i] != stat_len) { | 803 | if (skb->data[++i] != stat_len) { |
810 | printk(KERN_INFO "%s: Invalid LMI PVC status IE length" | 804 | netdev_info(dev, "Invalid LMI PVC status IE length (%u)\n", |
811 | " (%u)\n", dev->name, skb->data[i]); | 805 | skb->data[i]); |
812 | return 1; | 806 | return 1; |
813 | } | 807 | } |
814 | i++; | 808 | i++; |
@@ -829,9 +823,7 @@ static int fr_lmi_recv(struct net_device *dev, struct sk_buff *skb) | |||
829 | pvc = add_pvc(dev, dlci); | 823 | pvc = add_pvc(dev, dlci); |
830 | 824 | ||
831 | if (!pvc && !no_ram) { | 825 | if (!pvc && !no_ram) { |
832 | printk(KERN_WARNING | 826 | netdev_warn(dev, "Memory squeeze on fr_lmi_recv()\n"); |
833 | "%s: Memory squeeze on fr_lmi_recv()\n", | ||
834 | dev->name); | ||
835 | no_ram = 1; | 827 | no_ram = 1; |
836 | } | 828 | } |
837 | 829 | ||
@@ -902,8 +894,8 @@ static int fr_rx(struct sk_buff *skb) | |||
902 | pvc = find_pvc(hdlc, dlci); | 894 | pvc = find_pvc(hdlc, dlci); |
903 | if (!pvc) { | 895 | if (!pvc) { |
904 | #ifdef DEBUG_PKT | 896 | #ifdef DEBUG_PKT |
905 | printk(KERN_INFO "%s: No PVC for received frame's DLCI %d\n", | 897 | netdev_info(frad, "No PVC for received frame's DLCI %d\n", |
906 | frad->name, dlci); | 898 | dlci); |
907 | #endif | 899 | #endif |
908 | dev_kfree_skb_any(skb); | 900 | dev_kfree_skb_any(skb); |
909 | return NET_RX_DROP; | 901 | return NET_RX_DROP; |
@@ -962,14 +954,14 @@ static int fr_rx(struct sk_buff *skb) | |||
962 | break; | 954 | break; |
963 | 955 | ||
964 | default: | 956 | default: |
965 | printk(KERN_INFO "%s: Unsupported protocol, OUI=%x " | 957 | netdev_info(frad, "Unsupported protocol, OUI=%x PID=%x\n", |
966 | "PID=%x\n", frad->name, oui, pid); | 958 | oui, pid); |
967 | dev_kfree_skb_any(skb); | 959 | dev_kfree_skb_any(skb); |
968 | return NET_RX_DROP; | 960 | return NET_RX_DROP; |
969 | } | 961 | } |
970 | } else { | 962 | } else { |
971 | printk(KERN_INFO "%s: Unsupported protocol, NLPID=%x " | 963 | netdev_info(frad, "Unsupported protocol, NLPID=%x length=%i\n", |
972 | "length = %i\n", frad->name, data[3], skb->len); | 964 | data[3], skb->len); |
973 | dev_kfree_skb_any(skb); | 965 | dev_kfree_skb_any(skb); |
974 | return NET_RX_DROP; | 966 | return NET_RX_DROP; |
975 | } | 967 | } |
@@ -1073,8 +1065,7 @@ static int fr_add_pvc(struct net_device *frad, unsigned int dlci, int type) | |||
1073 | int used; | 1065 | int used; |
1074 | 1066 | ||
1075 | if ((pvc = add_pvc(frad, dlci)) == NULL) { | 1067 | if ((pvc = add_pvc(frad, dlci)) == NULL) { |
1076 | printk(KERN_WARNING "%s: Memory squeeze on fr_add_pvc()\n", | 1068 | netdev_warn(frad, "Memory squeeze on fr_add_pvc()\n"); |
1077 | frad->name); | ||
1078 | return -ENOBUFS; | 1069 | return -ENOBUFS; |
1079 | } | 1070 | } |
1080 | 1071 | ||
@@ -1089,8 +1080,7 @@ static int fr_add_pvc(struct net_device *frad, unsigned int dlci, int type) | |||
1089 | dev = alloc_netdev(0, "pvc%d", pvc_setup); | 1080 | dev = alloc_netdev(0, "pvc%d", pvc_setup); |
1090 | 1081 | ||
1091 | if (!dev) { | 1082 | if (!dev) { |
1092 | printk(KERN_WARNING "%s: Memory squeeze on fr_pvc()\n", | 1083 | netdev_warn(frad, "Memory squeeze on fr_pvc()\n"); |
1093 | frad->name); | ||
1094 | delete_unused_pvcs(hdlc); | 1084 | delete_unused_pvcs(hdlc); |
1095 | return -ENOBUFS; | 1085 | return -ENOBUFS; |
1096 | } | 1086 | } |