diff options
Diffstat (limited to 'drivers/s390/net/qeth.h')
-rw-r--r-- | drivers/s390/net/qeth.h | 25 |
1 files changed, 16 insertions, 9 deletions
diff --git a/drivers/s390/net/qeth.h b/drivers/s390/net/qeth.h index 619f4a0c7160..e8bd8c5ced1f 100644 --- a/drivers/s390/net/qeth.h +++ b/drivers/s390/net/qeth.h | |||
@@ -1096,10 +1096,11 @@ qeth_string_to_ipaddr4(const char *buf, __u8 *addr) | |||
1096 | { | 1096 | { |
1097 | int count = 0, rc = 0; | 1097 | int count = 0, rc = 0; |
1098 | int in[4]; | 1098 | int in[4]; |
1099 | char c; | ||
1099 | 1100 | ||
1100 | rc = sscanf(buf, "%d.%d.%d.%d%n", | 1101 | rc = sscanf(buf, "%u.%u.%u.%u%c", |
1101 | &in[0], &in[1], &in[2], &in[3], &count); | 1102 | &in[0], &in[1], &in[2], &in[3], &c); |
1102 | if (rc != 4 || count<=0) | 1103 | if (rc != 4 && (rc != 5 || c != '\n')) |
1103 | return -EINVAL; | 1104 | return -EINVAL; |
1104 | for (count = 0; count < 4; count++) { | 1105 | for (count = 0; count < 4; count++) { |
1105 | if (in[count] > 255) | 1106 | if (in[count] > 255) |
@@ -1123,24 +1124,28 @@ qeth_ipaddr6_to_string(const __u8 *addr, char *buf) | |||
1123 | static inline int | 1124 | static inline int |
1124 | qeth_string_to_ipaddr6(const char *buf, __u8 *addr) | 1125 | qeth_string_to_ipaddr6(const char *buf, __u8 *addr) |
1125 | { | 1126 | { |
1126 | char *end, *start; | 1127 | const char *end, *end_tmp, *start; |
1127 | __u16 *in; | 1128 | __u16 *in; |
1128 | char num[5]; | 1129 | char num[5]; |
1129 | int num2, cnt, out, found, save_cnt; | 1130 | int num2, cnt, out, found, save_cnt; |
1130 | unsigned short in_tmp[8] = {0, }; | 1131 | unsigned short in_tmp[8] = {0, }; |
1131 | 1132 | ||
1132 | cnt = out = found = save_cnt = num2 = 0; | 1133 | cnt = out = found = save_cnt = num2 = 0; |
1133 | end = start = (char *) buf; | 1134 | end = start = buf; |
1134 | in = (__u16 *) addr; | 1135 | in = (__u16 *) addr; |
1135 | memset(in, 0, 16); | 1136 | memset(in, 0, 16); |
1136 | while (end) { | 1137 | while (*end) { |
1137 | end = strchr(end,':'); | 1138 | end = strchr(start,':'); |
1138 | if (end == NULL) { | 1139 | if (end == NULL) { |
1139 | end = (char *)buf + (strlen(buf)); | 1140 | end = buf + strlen(buf); |
1140 | out = 1; | 1141 | if ((end_tmp = strchr(start, '\n')) != NULL) |
1142 | end = end_tmp; | ||
1143 | out = 1; | ||
1141 | } | 1144 | } |
1142 | if ((end - start)) { | 1145 | if ((end - start)) { |
1143 | memset(num, 0, 5); | 1146 | memset(num, 0, 5); |
1147 | if ((end - start) > 4) | ||
1148 | return -EINVAL; | ||
1144 | memcpy(num, start, end - start); | 1149 | memcpy(num, start, end - start); |
1145 | if (!qeth_isxdigit(num)) | 1150 | if (!qeth_isxdigit(num)) |
1146 | return -EINVAL; | 1151 | return -EINVAL; |
@@ -1158,6 +1163,8 @@ qeth_string_to_ipaddr6(const char *buf, __u8 *addr) | |||
1158 | } | 1163 | } |
1159 | start = ++end; | 1164 | start = ++end; |
1160 | } | 1165 | } |
1166 | if (cnt + save_cnt > 8) | ||
1167 | return -EINVAL; | ||
1161 | cnt = 7; | 1168 | cnt = 7; |
1162 | while (save_cnt) | 1169 | while (save_cnt) |
1163 | in[cnt--] = in_tmp[--save_cnt]; | 1170 | in[cnt--] = in_tmp[--save_cnt]; |