mirror of
https://github.com/cesanta/mongoose.git
synced 2025-01-14 17:58:11 +08:00
Fix endianness issues in unit test
This commit is contained in:
parent
b5355307a3
commit
88097f1829
32
mongoose.c
32
mongoose.c
@ -2802,18 +2802,16 @@ void mg_hexdump(const void *buf, size_t len) {
|
|||||||
#if defined(MG_ENABLE_MD5) && MG_ENABLE_MD5
|
#if defined(MG_ENABLE_MD5) && MG_ENABLE_MD5
|
||||||
|
|
||||||
static void mg_byte_reverse(unsigned char *buf, unsigned longs) {
|
static void mg_byte_reverse(unsigned char *buf, unsigned longs) {
|
||||||
/* Forrest: MD5 expect LITTLE_ENDIAN, swap if BIG_ENDIAN */
|
if (MG_BIG_ENDIAN) {
|
||||||
#if BYTE_ORDER == BIG_ENDIAN
|
do {
|
||||||
do {
|
uint32_t t = (uint32_t) ((unsigned) buf[3] << 8 | buf[2]) << 16 |
|
||||||
uint32_t t = (uint32_t) ((unsigned) buf[3] << 8 | buf[2]) << 16 |
|
((unsigned) buf[1] << 8 | buf[0]);
|
||||||
((unsigned) buf[1] << 8 | buf[0]);
|
*(uint32_t *) buf = t;
|
||||||
*(uint32_t *) buf = t;
|
buf += 4;
|
||||||
buf += 4;
|
} while (--longs);
|
||||||
} while (--longs);
|
} else {
|
||||||
#else
|
(void) buf, (void) longs; // Little endian. Do nothing
|
||||||
(void) buf;
|
}
|
||||||
(void) longs;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define F1(x, y, z) (z ^ (x & (y ^ z)))
|
#define F1(x, y, z) (z ^ (x & (y ^ z)))
|
||||||
@ -3646,11 +3644,11 @@ union char64long16 {
|
|||||||
#define rol(value, bits) (((value) << (bits)) | ((value) >> (32 - (bits))))
|
#define rol(value, bits) (((value) << (bits)) | ((value) >> (32 - (bits))))
|
||||||
|
|
||||||
static uint32_t blk0(union char64long16 *block, int i) {
|
static uint32_t blk0(union char64long16 *block, int i) {
|
||||||
/* Forrest: SHA expect BIG_ENDIAN, swap if LITTLE_ENDIAN */
|
if (MG_BIG_ENDIAN) {
|
||||||
#if BYTE_ORDER == LITTLE_ENDIAN
|
} else {
|
||||||
block->l[i] =
|
block->l[i] = (rol(block->l[i], 24) & 0xFF00FF00) |
|
||||||
(rol(block->l[i], 24) & 0xFF00FF00) | (rol(block->l[i], 8) & 0x00FF00FF);
|
(rol(block->l[i], 8) & 0x00FF00FF);
|
||||||
#endif
|
}
|
||||||
return block->l[i];
|
return block->l[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
20
mongoose.h
20
mongoose.h
@ -61,21 +61,6 @@ extern "C" {
|
|||||||
#define MG_ARCH MG_ARCH_RP2040
|
#define MG_ARCH MG_ARCH_RP2040
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
|
||||||
* clang with std=-c99 uses __LITTLE_ENDIAN, by default
|
|
||||||
* while for ex, RTOS gcc - LITTLE_ENDIAN, by default
|
|
||||||
* it depends on __USE_BSD, but let's have everything
|
|
||||||
*/
|
|
||||||
#if !defined(BYTE_ORDER) && defined(__BYTE_ORDER)
|
|
||||||
#define BYTE_ORDER __BYTE_ORDER
|
|
||||||
#ifndef LITTLE_ENDIAN
|
|
||||||
#define LITTLE_ENDIAN __LITTLE_ENDIAN
|
|
||||||
#endif /* LITTLE_ENDIAN */
|
|
||||||
#ifndef BIG_ENDIAN
|
|
||||||
#define BIG_ENDIAN __LITTLE_ENDIAN
|
|
||||||
#endif /* BIG_ENDIAN */
|
|
||||||
#endif /* BYTE_ORDER */
|
|
||||||
|
|
||||||
#if !defined(MG_ARCH)
|
#if !defined(MG_ARCH)
|
||||||
#include "mongoose_custom.h" // keep this include
|
#include "mongoose_custom.h" // keep this include
|
||||||
#endif
|
#endif
|
||||||
@ -85,6 +70,9 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
#endif // !defined(MG_ARCH)
|
#endif // !defined(MG_ARCH)
|
||||||
|
|
||||||
|
// http://esr.ibiblio.org/?p=5095
|
||||||
|
#define MG_BIG_ENDIAN (*(uint16_t *)"\0\xff" < 0x100)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -659,7 +647,7 @@ int sscanf(const char *, const char *, ...);
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef MG_ENABLE_MD5
|
#ifndef MG_ENABLE_MD5
|
||||||
#define MG_ENABLE_MD5 0
|
#define MG_ENABLE_MD5 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Set MG_ENABLE_WINSOCK=0 for Win32 builds with external IP stack (like LWIP)
|
// Set MG_ENABLE_WINSOCK=0 for Win32 builds with external IP stack (like LWIP)
|
||||||
|
18
src/arch.h
18
src/arch.h
@ -34,21 +34,6 @@
|
|||||||
#define MG_ARCH MG_ARCH_RP2040
|
#define MG_ARCH MG_ARCH_RP2040
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
|
||||||
* clang with std=-c99 uses __LITTLE_ENDIAN, by default
|
|
||||||
* while for ex, RTOS gcc - LITTLE_ENDIAN, by default
|
|
||||||
* it depends on __USE_BSD, but let's have everything
|
|
||||||
*/
|
|
||||||
#if !defined(BYTE_ORDER) && defined(__BYTE_ORDER)
|
|
||||||
#define BYTE_ORDER __BYTE_ORDER
|
|
||||||
#ifndef LITTLE_ENDIAN
|
|
||||||
#define LITTLE_ENDIAN __LITTLE_ENDIAN
|
|
||||||
#endif /* LITTLE_ENDIAN */
|
|
||||||
#ifndef BIG_ENDIAN
|
|
||||||
#define BIG_ENDIAN __LITTLE_ENDIAN
|
|
||||||
#endif /* BIG_ENDIAN */
|
|
||||||
#endif /* BYTE_ORDER */
|
|
||||||
|
|
||||||
#if !defined(MG_ARCH)
|
#if !defined(MG_ARCH)
|
||||||
#include "mongoose_custom.h" // keep this include
|
#include "mongoose_custom.h" // keep this include
|
||||||
#endif
|
#endif
|
||||||
@ -58,6 +43,9 @@
|
|||||||
#endif
|
#endif
|
||||||
#endif // !defined(MG_ARCH)
|
#endif // !defined(MG_ARCH)
|
||||||
|
|
||||||
|
// http://esr.ibiblio.org/?p=5095
|
||||||
|
#define MG_BIG_ENDIAN (*(uint16_t *)"\0\xff" < 0x100)
|
||||||
|
|
||||||
#include "arch_esp32.h"
|
#include "arch_esp32.h"
|
||||||
#include "arch_esp8266.h"
|
#include "arch_esp8266.h"
|
||||||
#include "arch_freertos_lwip.h"
|
#include "arch_freertos_lwip.h"
|
||||||
|
@ -45,7 +45,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef MG_ENABLE_MD5
|
#ifndef MG_ENABLE_MD5
|
||||||
#define MG_ENABLE_MD5 0
|
#define MG_ENABLE_MD5 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Set MG_ENABLE_WINSOCK=0 for Win32 builds with external IP stack (like LWIP)
|
// Set MG_ENABLE_WINSOCK=0 for Win32 builds with external IP stack (like LWIP)
|
||||||
|
24
src/md5.c
24
src/md5.c
@ -1,21 +1,19 @@
|
|||||||
#include "md5.h"
|
|
||||||
#include "arch.h"
|
#include "arch.h"
|
||||||
|
#include "md5.h"
|
||||||
|
|
||||||
#if defined(MG_ENABLE_MD5) && MG_ENABLE_MD5
|
#if defined(MG_ENABLE_MD5) && MG_ENABLE_MD5
|
||||||
|
|
||||||
static void mg_byte_reverse(unsigned char *buf, unsigned longs) {
|
static void mg_byte_reverse(unsigned char *buf, unsigned longs) {
|
||||||
/* Forrest: MD5 expect LITTLE_ENDIAN, swap if BIG_ENDIAN */
|
if (MG_BIG_ENDIAN) {
|
||||||
#if BYTE_ORDER == BIG_ENDIAN
|
do {
|
||||||
do {
|
uint32_t t = (uint32_t) ((unsigned) buf[3] << 8 | buf[2]) << 16 |
|
||||||
uint32_t t = (uint32_t) ((unsigned) buf[3] << 8 | buf[2]) << 16 |
|
((unsigned) buf[1] << 8 | buf[0]);
|
||||||
((unsigned) buf[1] << 8 | buf[0]);
|
*(uint32_t *) buf = t;
|
||||||
*(uint32_t *) buf = t;
|
buf += 4;
|
||||||
buf += 4;
|
} while (--longs);
|
||||||
} while (--longs);
|
} else {
|
||||||
#else
|
(void) buf, (void) longs; // Little endian. Do nothing
|
||||||
(void) buf;
|
}
|
||||||
(void) longs;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define F1(x, y, z) (z ^ (x & (y ^ z)))
|
#define F1(x, y, z) (z ^ (x & (y ^ z)))
|
||||||
|
12
src/sha1.c
12
src/sha1.c
@ -1,7 +1,7 @@
|
|||||||
/* Copyright(c) By Steve Reid <steve@edmweb.com> */
|
/* Copyright(c) By Steve Reid <steve@edmweb.com> */
|
||||||
/* 100% Public Domain */
|
/* 100% Public Domain */
|
||||||
#include "sha1.h"
|
|
||||||
#include "arch.h"
|
#include "arch.h"
|
||||||
|
#include "sha1.h"
|
||||||
|
|
||||||
union char64long16 {
|
union char64long16 {
|
||||||
unsigned char c[64];
|
unsigned char c[64];
|
||||||
@ -11,11 +11,11 @@ union char64long16 {
|
|||||||
#define rol(value, bits) (((value) << (bits)) | ((value) >> (32 - (bits))))
|
#define rol(value, bits) (((value) << (bits)) | ((value) >> (32 - (bits))))
|
||||||
|
|
||||||
static uint32_t blk0(union char64long16 *block, int i) {
|
static uint32_t blk0(union char64long16 *block, int i) {
|
||||||
/* Forrest: SHA expect BIG_ENDIAN, swap if LITTLE_ENDIAN */
|
if (MG_BIG_ENDIAN) {
|
||||||
#if BYTE_ORDER == LITTLE_ENDIAN
|
} else {
|
||||||
block->l[i] =
|
block->l[i] = (rol(block->l[i], 24) & 0xFF00FF00) |
|
||||||
(rol(block->l[i], 24) & 0xFF00FF00) | (rol(block->l[i], 8) & 0x00FF00FF);
|
(rol(block->l[i], 8) & 0x00FF00FF);
|
||||||
#endif
|
}
|
||||||
return block->l[i];
|
return block->l[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -777,9 +777,7 @@ static void test_http_server(void) {
|
|||||||
fetch(&mgr, buf, url, "GET /test/ HTTP/1.0\n\n");
|
fetch(&mgr, buf, url, "GET /test/ HTTP/1.0\n\n");
|
||||||
ASSERT(fetch(&mgr, buf, url, "GET /test/ HTTP/1.0\n\n") == 200);
|
ASSERT(fetch(&mgr, buf, url, "GET /test/ HTTP/1.0\n\n") == 200);
|
||||||
ASSERT(mg_strstr(mg_str(buf), mg_str(">Index of /test/<")) != NULL);
|
ASSERT(mg_strstr(mg_str(buf), mg_str(">Index of /test/<")) != NULL);
|
||||||
#if BYTE_ORDER != BIG_ENDIAN
|
|
||||||
ASSERT(mg_strstr(mg_str(buf), mg_str(">fuzz.c<")) != NULL);
|
ASSERT(mg_strstr(mg_str(buf), mg_str(">fuzz.c<")) != NULL);
|
||||||
#endif
|
|
||||||
|
|
||||||
{
|
{
|
||||||
// Credentials
|
// Credentials
|
||||||
@ -1730,9 +1728,7 @@ static void test_util(void) {
|
|||||||
ASSERT(mg_aton(mg_str("0.0.0.-1"), &a) == false);
|
ASSERT(mg_aton(mg_str("0.0.0.-1"), &a) == false);
|
||||||
ASSERT(mg_aton(mg_str("127.0.0.1"), &a) == true);
|
ASSERT(mg_aton(mg_str("127.0.0.1"), &a) == true);
|
||||||
ASSERT(a.is_ip6 == false);
|
ASSERT(a.is_ip6 == false);
|
||||||
#if BYTE_ORDER != BIG_ENDIAN
|
ASSERT(a.ip == mg_htonl(0x7f000001));
|
||||||
ASSERT(a.ip == 0x100007f);
|
|
||||||
#endif
|
|
||||||
ASSERT(strcmp(mg_ntoa(&a, buf, sizeof(buf)), "127.0.0.1") == 0);
|
ASSERT(strcmp(mg_ntoa(&a, buf, sizeof(buf)), "127.0.0.1") == 0);
|
||||||
|
|
||||||
ASSERT(mg_aton(mg_str("1:2:3:4:5:6:7:8"), &a) == true);
|
ASSERT(mg_aton(mg_str("1:2:3:4:5:6:7:8"), &a) == true);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user