Unverified Commit 486caf42 authored by Earle F. Philhower, III's avatar Earle F. Philhower, III Committed by GitHub

Remove microscopic malloc() from WebServer (#809)

Don't try and heap allocate temporaty <16b chunks.
parent 92f2ca91
...@@ -87,10 +87,7 @@ static String md5str(String &in) { ...@@ -87,10 +87,7 @@ static String md5str(String &in) {
char out[33] = {0}; char out[33] = {0};
MD5Builder _ctx; MD5Builder _ctx;
uint8_t i; uint8_t i;
uint8_t * _buf = (uint8_t*)malloc(16); uint8_t _buf[16];
if (_buf == NULL) {
return String(out);
}
memset(_buf, 0x00, 16); memset(_buf, 0x00, 16);
_ctx.begin(); _ctx.begin();
_ctx.add((const uint8_t *)in.c_str(), in.length()); _ctx.add((const uint8_t *)in.c_str(), in.length());
...@@ -100,7 +97,6 @@ static String md5str(String &in) { ...@@ -100,7 +97,6 @@ static String md5str(String &in) {
sprintf(out + (i * 2), "%02x", _buf[i]); sprintf(out + (i * 2), "%02x", _buf[i]);
} }
out[32] = 0; out[32] = 0;
free(_buf);
return String(out); return String(out);
} }
...@@ -443,12 +439,9 @@ void HTTPServer::sendContent(const String& content) { ...@@ -443,12 +439,9 @@ void HTTPServer::sendContent(const String& content) {
void HTTPServer::sendContent(const char* content, size_t contentLength) { void HTTPServer::sendContent(const char* content, size_t contentLength) {
const char * footer = "\r\n"; const char * footer = "\r\n";
if (_chunked) { if (_chunked) {
char * chunkSize = (char *)malloc(11); char chunkSize[11];
if (chunkSize) {
sprintf(chunkSize, "%x%s", contentLength, footer); sprintf(chunkSize, "%x%s", contentLength, footer);
_currentClientWrite(chunkSize, strlen(chunkSize)); _currentClientWrite(chunkSize, strlen(chunkSize));
free(chunkSize);
}
} }
_currentClientWrite(content, contentLength); _currentClientWrite(content, contentLength);
if (_chunked) { if (_chunked) {
...@@ -466,12 +459,9 @@ void HTTPServer::sendContent_P(PGM_P content) { ...@@ -466,12 +459,9 @@ void HTTPServer::sendContent_P(PGM_P content) {
void HTTPServer::sendContent_P(PGM_P content, size_t size) { void HTTPServer::sendContent_P(PGM_P content, size_t size) {
const char * footer = "\r\n"; const char * footer = "\r\n";
if (_chunked) { if (_chunked) {
char * chunkSize = (char *)malloc(11); char chunkSize[11];
if (chunkSize) {
sprintf(chunkSize, "%x%s", size, footer); sprintf(chunkSize, "%x%s", size, footer);
_currentClientWrite(chunkSize, strlen(chunkSize)); _currentClientWrite(chunkSize, strlen(chunkSize));
free(chunkSize);
}
} }
_currentClientWrite_P(content, size); _currentClientWrite_P(content, size);
if (_chunked) { if (_chunked) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment