api: fixes for windows (to finish)

This commit is contained in:
Tanguy Pruvot 2014-11-12 12:53:30 +01:00
parent 4958ce6007
commit f58b2d3d21
3 changed files with 30 additions and 17 deletions

39
api.c
View File

@ -10,6 +10,12 @@
*/
#define APIVERSION "1.0"
#ifdef _MSC_VER
# define _WINSOCK_DEPRECATED_NO_WARNINGS
# include <winsock2.h>
# include <mstcpip.h>
#endif
#include <stdio.h>
#include <ctype.h>
#include <stdlib.h>
@ -29,7 +35,7 @@
#include "compat.h"
#include "miner.h"
#ifndef WIN32
#ifndef _MSC_VER
# include <errno.h>
# include <sys/socket.h>
# include <netinet/in.h>
@ -43,12 +49,12 @@
# define SOCKETINIT {}
# define SOCKERRMSG strerror(errno)
#else
# include <winsock2.h>
# define SOCKETTYPE SOCKET
# define SOCKETFAIL(a) ((a) == SOCKET_ERROR)
# define INVSOCK INVALID_SOCKET
# define INVINETADDR INADDR_NONE
# define CLOSESOCKET closesocket
#define in_addr_t uint32_t
#endif
#define GROUP(g) (toupper(g))
@ -125,7 +131,9 @@ static void gpustatus(int thr_id)
}
else
#endif
gt = gf = gp = 0;
{
gt = 0.0; gf = gp = 0;
}
// todo: can be 0 if set by algo (auto)
if (opt_intensity == 0 && opt_work_size) {
@ -186,7 +194,7 @@ struct CMDS {
#define CMDMAX 2
static void send_result(int c, char *result)
static void send_result(SOCKETTYPE c, char *result)
{
int n;
@ -194,7 +202,7 @@ static void send_result(int c, char *result)
result = "";
// ignore failure - it's closed immediately anyway
n = write(c, result, strlen(result)+1);
n = send(c, result, strlen(result) + 1, 0);
}
/*
@ -211,7 +219,7 @@ static void setup_ipaccess()
int ipcount, mask, octet, i;
char group;
buf = malloc(strlen(opt_api_allow) + 1);
buf = (char*) calloc(1, strlen(opt_api_allow) + 1);
if (unlikely(!buf))
proper_exit(1);//, "Failed to malloc ipaccess buf");
@ -223,7 +231,11 @@ static void setup_ipaccess()
ipcount++;
// possibly more than needed, but never less
#ifdef _MSC_VER
ipaccess = (IP4ACCESS *) calloc(ipcount, sizeof(struct IP4ACCESS));
#else
ipaccess = calloc(ipcount, sizeof(struct IP4ACCESS));
#endif
if (unlikely(!ipaccess))
proper_exit(1);//, "Failed to calloc ipaccess");
@ -354,7 +366,7 @@ static void api()
}
}
apisock = calloc(1, sizeof(*apisock));
apisock = (SOCKETTYPE*) calloc(1, sizeof(*apisock));
*apisock = INVSOCK;
sleep(1);
@ -420,7 +432,7 @@ static void api()
return;
}
buffer = malloc(MYBUFSIZ+1);
buffer = (char *) calloc(1, MYBUFSIZ + 1);
counter = 0;
while (bye == 0) {
@ -441,10 +453,9 @@ static void api()
connectaddr, addrok ? "Accepted" : "Ignored");
if (addrok) {
n = read(c, &buf[0], BUFSIZ-1);
if (n < 0)
close(c);
else {
n = recv(c, &buf[0], BUFSIZ - 1, 0);
// applog(LOG_DEBUG, "API: recv command: (%d) '%s'", n, buf);
if (!SOCKETFAIL(n)) {
buf[n] = '\0';
params = strchr(buf, '|');
if (params != NULL)
@ -454,7 +465,7 @@ static void api()
if (strcmp(buf, cmds[i].name) == 0) {
result = (cmds[i].func)(params);
send_result(c, result);
close(c);
CLOSESOCKET(c);
break;
}
}
@ -476,4 +487,4 @@ void *api_thread(void *userdata)
tq_freeze(mythr->q);
return NULL;
}
}

View File

@ -240,7 +240,9 @@
<ClCompile Include="groestlcoin.cpp" />
<ClCompile Include="hashlog.cpp" />
<ClCompile Include="stats.cpp" />
<ClCompile Include="api.c" />
<ClCompile Include="api.c">
<AdditionalOptions>/Tp %(AdditionalOptions)</AdditionalOptions>
</ClCompile>
<ClCompile Include="hefty1.c" />
<ClCompile Include="myriadgroestl.cpp" />
<ClCompile Include="scrypt.c">

View File

@ -192,7 +192,7 @@
<ClCompile Include="stats.cpp">
<Filter>Source Files</Filter>
</ClCompile>
<ClCompile Include="api.cpp">
<ClCompile Include="api.c">
<Filter>Source Files</Filter>
</ClCompile>
</ItemGroup>
@ -482,4 +482,4 @@
<Filter>Source Files\CUDA\x11</Filter>
</CudaCompile>
</ItemGroup>
</Project>
</Project>