tidy up memory usage

This commit is contained in:
dborth 2010-07-31 02:21:36 +00:00
parent fb0ed2eb65
commit 8157e9b064

View File

@ -108,57 +108,39 @@ static s32 tcp_connect(char *host, const u16 port)
return s; return s;
} }
static char * tcp_readln(const s32 s, const u16 max_length, const u64 start_time, static int tcp_readln(const s32 s, char *buf, const u16 max_length)
const u16 timeout)
{ {
char *buf; s32 res = -1;
u16 c; s32 ret;
s32 res; u64 start_time = gettime();
char *ret; u16 c = 0;
buf = (char *) malloc(max_length); while (c < max_length)
c = 0;
ret = NULL;
while (true)
{ {
if (ticks_to_millisecs(diff_ticks(start_time, gettime())) > timeout) if (ticks_to_millisecs(diff_ticks(start_time, gettime())) > HTTP_TIMEOUT)
break; break;
res = net_read(s, &buf[c], 1); ret = net_read(s, &buf[c], 1);
if ((res == 0) || (res == -EAGAIN)) if (ret == 0 || ret == -EAGAIN)
{ {
usleep(20 * 1000); usleep(20 * 1000);
continue; continue;
} }
if (res < 0) if (ret < 0)
break; break;
if ((c > 0) && (buf[c - 1] == '\r') && (buf[c] == '\n')) if (c > 0 && buf[c - 1] == '\r' && buf[c] == '\n')
{ {
if (c == 1) res = 0;
{ buf[c-1] = 0;
ret = strdup("");
break;
}
ret = strndup(buf, c - 1);
break; break;
} }
c++; c++;
usleep(100);
if (c == max_length)
break;
usleep(300);
} }
return res;
free(buf);
return ret;
} }
static int tcp_read(const s32 s, u8 *buffer, const u32 length) static int tcp_read(const s32 s, u8 *buffer, const u32 length)
@ -258,7 +240,8 @@ static int tcp_write(const s32 s, const u8 *buffer, const u32 length)
return left == 0; return left == 0;
} }
static bool http_split_url(char **host, char **path, const char *url)
static bool http_split_url(char *host, char *path, const char *url)
{ {
const char *p; const char *p;
char *c; char *c;
@ -272,9 +255,8 @@ static bool http_split_url(char **host, char **path, const char *url)
if (c == NULL || c[0] == 0) if (c == NULL || c[0] == 0)
return false; return false;
*host = strndup(p, c - p); snprintf(host, c-p, "%s", p);
*path = strdup(c); strcpy(path, c);
return true; return true;
} }
@ -284,12 +266,12 @@ static bool http_split_url(char **host, char **path, const char *url)
* http_request * http_request
* Retrieves the specified URL, and stores it in the specified file or buffer * Retrieves the specified URL, and stores it in the specified file or buffer
***************************************************************************/ ***************************************************************************/
int http_request(const char *url, FILE * hfile, u8 * buffer, u32 maxsize, bool silent) int http_request(const char *url, FILE *hfile, u8 *buffer, u32 maxsize, bool silent)
{ {
int res = 0; int res = 0;
char *http_host; char http_host[1024];
char http_path[1024];
u16 http_port; u16 http_port;
char *http_path;
http_res result; http_res result;
u32 http_status; u32 http_status;
@ -302,8 +284,8 @@ int http_request(const char *url, FILE * hfile, u8 * buffer, u32 maxsize, bool s
if (url == NULL || (hfile == NULL && buffer == NULL)) if (url == NULL || (hfile == NULL && buffer == NULL))
return 0; return 0;
if (!http_split_url(&http_host, &http_path, url)) if (!http_split_url(http_host, http_path, url))
return 0; return 0;
http_port = 80; http_port = 80;
@ -317,7 +299,7 @@ int http_request(const char *url, FILE * hfile, u8 * buffer, u32 maxsize, bool s
return 0; return 0;
} }
char *request = (char *) malloc(1024); char request[1024];
char *r = request; char *r = request;
r += sprintf(r, "GET %s HTTP/1.1\r\n", http_path); r += sprintf(r, "GET %s HTTP/1.1\r\n", http_path);
@ -326,13 +308,11 @@ int http_request(const char *url, FILE * hfile, u8 * buffer, u32 maxsize, bool s
res = tcp_write(s, (u8 *) request, strlen(request)); res = tcp_write(s, (u8 *) request, strlen(request));
free(request); char line[256];
for (linecount = 0; linecount < 32; linecount++) for (linecount = 0; linecount < 32; linecount++)
{ {
char *line = tcp_readln(s, 0xff, gettime(), (const u16) HTTP_TIMEOUT); if (tcp_readln(s, line, 255) != 0)
if (!line)
{ {
http_status = 404; http_status = 404;
result = HTTPR_ERR_REQUEST; result = HTTPR_ERR_REQUEST;
@ -340,18 +320,10 @@ int http_request(const char *url, FILE * hfile, u8 * buffer, u32 maxsize, bool s
} }
if (strlen(line) < 1) if (strlen(line) < 1)
{
free(line);
line = NULL;
break; break;
}
sscanf(line, "HTTP/1.%*u %u", &http_status); sscanf(line, "HTTP/1.%*u %u", &http_status);
sscanf(line, "Content-Length: %u", &content_length); sscanf(line, "Content-Length: %u", &content_length);
free(line);
line = NULL;
} }
if (http_status != 200) if (http_status != 200)
@ -386,7 +358,7 @@ int http_request(const char *url, FILE * hfile, u8 * buffer, u32 maxsize, bool s
else else
{ {
// read into file // read into file
u32 bufSize = (1026 * 256); u32 bufSize = (1024 * 32);
u32 bytesLeft = content_length; u32 bytesLeft = content_length;
u32 readSize; u32 readSize;