X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Usermode%2FLibraries%2Flibnet.so_src%2Faddress.c;h=8887362d69a52a765023e5228e5162d019713642;hb=038439147795891da9d99ddbc10ebbbb0d9fca09;hp=0430c84d44def7cd4ee8d2904e684e0bd41abc81;hpb=7536e8afcc3018c4ca2a4aa8f8422cf86a6c188c;p=tpg%2Facess2.git diff --git a/Usermode/Libraries/libnet.so_src/address.c b/Usermode/Libraries/libnet.so_src/address.c index 0430c84d..8887362d 100644 --- a/Usermode/Libraries/libnet.so_src/address.c +++ b/Usermode/Libraries/libnet.so_src/address.c @@ -7,7 +7,8 @@ */ #include #include -#include +//#include +#include #define DEBUG 0 static inline uint32_t htonl(uint32_t v) @@ -37,43 +38,50 @@ static inline uint16_t htons(uint16_t v) */ static int Net_ParseIPv4Addr(const char *String, uint8_t *Addr) { - int i = 0; int j; - int val; + const char *pos = String; - for( j = 0; String[i] && j < 4; j ++ ) + for( j = 0; *pos && j < 4; j ++ ) { - val = 0; - for( ; String[i] && String[i] != '.'; i++ ) - { - if('0' > String[i] || String[i] > '9') { - #if DEBUG - printf("0 255) { #if DEBUG - printf("val > 255 (%i)\n", val); + _SysDebug("%s: val > 255 (%i)", __func__, val); #endif return 0; } + #if DEBUG + _SysDebug("%s: Comp '%.*s' = %lu", __func__, end - pos, pos, val); + #endif Addr[j] = val; - if(String[i] == '.') - i ++; + pos = end; + + if(*pos == '.') + pos ++; } if( j != 4 ) { #if DEBUG - printf("4 parts expected, %i found\n", j); + _SysDebug("%s: 4 parts expected, %i found", __func__, j); #endif return 0; } - if(String[i] != '\0') { + if(*pos != '\0') { #if DEBUG - printf("EOS != '\\0', '%c'\n", String[i]); + _SysDebug("%s: EOS != '\\0', '%c'", __func__, *pos); #endif return 0; } @@ -160,8 +168,8 @@ static int Net_ParseIPv6Addr(const char *String, uint8_t *Addr) k = 0; for( ; j < 8; j ++, k++) { - Addr[j*2] = hi[k]>>8; - Addr[j*2+1] = hi[k]&0xFF; + Addr[j*2] = low[k]>>8; + Addr[j*2+1] = low[k]&0xFF; } return 1; @@ -187,7 +195,7 @@ int Net_ParseAddress(const char *String, void *Addr) return 0; } -static const char *Net_PrintIPv4Address(uint8_t *Address) +static const char *Net_PrintIPv4Address(const uint8_t *Address) { static __thread char ret[4*3+3+1]; // '255.255.255.255\0' @@ -196,7 +204,7 @@ static const char *Net_PrintIPv4Address(uint8_t *Address) return ret; } -static const char *Net_PrintIPv6Address(uint16_t *Address) +static const char *Net_PrintIPv6Address(const uint16_t *Address) { static __thread char ret[8*4+7+1]; // 'FFFF:FFFF:FFFF:FFFF:FFFF:FFFF:FFFF:FFFF\0' #if 0 @@ -215,7 +223,7 @@ static const char *Net_PrintIPv6Address(uint16_t *Address) return ret; } -const char *Net_PrintAddress(int AddressType, void *Address) +const char *Net_PrintAddress(int AddressType, const void *Address) { switch( AddressType ) {