diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/tokenring/smctr.c | 36 |
1 files changed, 10 insertions, 26 deletions
diff --git a/drivers/net/tokenring/smctr.c b/drivers/net/tokenring/smctr.c index 6515894c83f5..23e012f5bbf4 100644 --- a/drivers/net/tokenring/smctr.c +++ b/drivers/net/tokenring/smctr.c | |||
@@ -3091,11 +3091,7 @@ static int smctr_lobe_media_test(struct net_device *dev) | |||
3091 | /* Setup the lobe media test. */ | 3091 | /* Setup the lobe media test. */ |
3092 | smctr_lobe_media_test_cmd(dev); | 3092 | smctr_lobe_media_test_cmd(dev); |
3093 | if(smctr_wait_cmd(dev)) | 3093 | if(smctr_wait_cmd(dev)) |
3094 | { | 3094 | goto err; |
3095 | smctr_reset_adapter(dev); | ||
3096 | tp->status = CLOSED; | ||
3097 | return (LOBE_MEDIA_TEST_FAILED); | ||
3098 | } | ||
3099 | 3095 | ||
3100 | /* Tx lobe media test frames. */ | 3096 | /* Tx lobe media test frames. */ |
3101 | for(i = 0; i < 1500; ++i) | 3097 | for(i = 0; i < 1500; ++i) |
@@ -3103,20 +3099,12 @@ static int smctr_lobe_media_test(struct net_device *dev) | |||
3103 | if(smctr_send_lobe_media_test(dev)) | 3099 | if(smctr_send_lobe_media_test(dev)) |
3104 | { | 3100 | { |
3105 | if(perror) | 3101 | if(perror) |
3106 | { | 3102 | goto err; |
3107 | smctr_reset_adapter(dev); | ||
3108 | tp->state = CLOSED; | ||
3109 | return (LOBE_MEDIA_TEST_FAILED); | ||
3110 | } | ||
3111 | else | 3103 | else |
3112 | { | 3104 | { |
3113 | perror = 1; | 3105 | perror = 1; |
3114 | if(smctr_lobe_media_test_cmd(dev)) | 3106 | if(smctr_lobe_media_test_cmd(dev)) |
3115 | { | 3107 | goto err; |
3116 | smctr_reset_adapter(dev); | ||
3117 | tp->state = CLOSED; | ||
3118 | return (LOBE_MEDIA_TEST_FAILED); | ||
3119 | } | ||
3120 | } | 3108 | } |
3121 | } | 3109 | } |
3122 | } | 3110 | } |
@@ -3124,28 +3112,24 @@ static int smctr_lobe_media_test(struct net_device *dev) | |||
3124 | if(smctr_send_dat(dev)) | 3112 | if(smctr_send_dat(dev)) |
3125 | { | 3113 | { |
3126 | if(smctr_send_dat(dev)) | 3114 | if(smctr_send_dat(dev)) |
3127 | { | 3115 | goto err; |
3128 | smctr_reset_adapter(dev); | ||
3129 | tp->state = CLOSED; | ||
3130 | return (LOBE_MEDIA_TEST_FAILED); | ||
3131 | } | ||
3132 | } | 3116 | } |
3133 | 3117 | ||
3134 | /* Check if any frames received during test. */ | 3118 | /* Check if any frames received during test. */ |
3135 | if((tp->rx_fcb_curr[MAC_QUEUE]->frame_status) | 3119 | if((tp->rx_fcb_curr[MAC_QUEUE]->frame_status) |
3136 | || (tp->rx_fcb_curr[NON_MAC_QUEUE]->frame_status)) | 3120 | || (tp->rx_fcb_curr[NON_MAC_QUEUE]->frame_status)) |
3137 | { | 3121 | goto err; |
3138 | smctr_reset_adapter(dev); | ||
3139 | tp->state = CLOSED; | ||
3140 | return (LOBE_MEDIA_TEST_FAILED); | ||
3141 | } | ||
3142 | 3122 | ||
3143 | /* Set receive mask to "Promisc" mode. */ | 3123 | /* Set receive mask to "Promisc" mode. */ |
3144 | tp->receive_mask = saved_rcv_mask; | 3124 | tp->receive_mask = saved_rcv_mask; |
3145 | 3125 | ||
3146 | smctr_chg_rx_mask(dev); | 3126 | smctr_chg_rx_mask(dev); |
3147 | 3127 | ||
3148 | return (0); | 3128 | return 0; |
3129 | err: | ||
3130 | smctr_reset_adapter(dev); | ||
3131 | tp->status = CLOSED; | ||
3132 | return LOBE_MEDIA_TEST_FAILED; | ||
3149 | } | 3133 | } |
3150 | 3134 | ||
3151 | static int smctr_lobe_media_test_cmd(struct net_device *dev) | 3135 | static int smctr_lobe_media_test_cmd(struct net_device *dev) |