pthreads testing (have to add a flag in cmake but don't remember which and internet is slow af rn)
This commit is contained in:
parent
3d93fc7758
commit
195d4352a0
18
main.c
18
main.c
@ -1,8 +1,22 @@
|
|||||||
#include "server.h"
|
//#include "server.h"
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
void threadTest(void *arg) {
|
||||||
|
char* txt = (char*) arg;
|
||||||
|
puts(txt);
|
||||||
|
pthread_exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
// TODO: shell args
|
// TODO: shell args
|
||||||
server(1, 1);
|
pthread_t threadHandle;
|
||||||
|
pthread_attr_t attr;
|
||||||
|
pthread_attr_init(&attr);
|
||||||
|
pthread_create(&threadHandle, &attr, (void *(*)(void *)) threadTest, "a");
|
||||||
|
void * ret;
|
||||||
|
pthread_join(threadHandle, &ret);
|
||||||
|
puts(ret);
|
||||||
|
// server(1, 1);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
33
server.c
33
server.c
@ -68,9 +68,8 @@ void tcpListen(int serverSocket, struct sockaddr * clientAddress, unsigned long
|
|||||||
}
|
}
|
||||||
|
|
||||||
void server(int tcp, int ipv6) {
|
void server(int tcp, int ipv6) {
|
||||||
int serverSocket, socketType, socketProtocol;
|
int socketType, socketProtocol;
|
||||||
unsigned long serverAddressLength, clientAddressLength;
|
struct sockinfo server, client;
|
||||||
struct sockaddr *serverAddress, *clientAddress;
|
|
||||||
struct sockaddr_in serverAddress4, clientAddress4;
|
struct sockaddr_in serverAddress4, clientAddress4;
|
||||||
struct sockaddr_in6 serverAddress6, clientAddress6;
|
struct sockaddr_in6 serverAddress6, clientAddress6;
|
||||||
|
|
||||||
@ -78,22 +77,24 @@ void server(int tcp, int ipv6) {
|
|||||||
serverAddress6.sin6_family = AF_INET6;
|
serverAddress6.sin6_family = AF_INET6;
|
||||||
serverAddress6.sin6_addr = in6addr_any;
|
serverAddress6.sin6_addr = in6addr_any;
|
||||||
serverAddress6.sin6_port = htons(DEFAULT_LISTEN_PORT);
|
serverAddress6.sin6_port = htons(DEFAULT_LISTEN_PORT);
|
||||||
serverAddress = (struct sockaddr *) &serverAddress6;
|
|
||||||
serverAddressLength = sizeof serverAddress6;
|
server.address = (struct sockaddr *) &serverAddress6;
|
||||||
|
server.addressLength = sizeof serverAddress6;
|
||||||
|
|
||||||
clientAddress6.sin6_family = AF_INET6;
|
clientAddress6.sin6_family = AF_INET6;
|
||||||
clientAddress = (struct sockaddr *) &clientAddress6;
|
client.address = (struct sockaddr *) &clientAddress6;
|
||||||
clientAddressLength = sizeof clientAddress6;
|
client.addressLength = sizeof clientAddress6;
|
||||||
} else {
|
} else {
|
||||||
serverAddress4.sin_family = AF_INET;
|
serverAddress4.sin_family = AF_INET;
|
||||||
serverAddress4.sin_addr.s_addr = INADDR_ANY;
|
serverAddress4.sin_addr.s_addr = INADDR_ANY;
|
||||||
serverAddress4.sin_port = htons(DEFAULT_LISTEN_PORT);
|
serverAddress4.sin_port = htons(DEFAULT_LISTEN_PORT);
|
||||||
serverAddress = (struct sockaddr *) &serverAddress4;
|
|
||||||
serverAddressLength = sizeof serverAddress4;
|
server.address = (struct sockaddr *) &serverAddress4;
|
||||||
|
server.addressLength = sizeof serverAddress4;
|
||||||
|
|
||||||
clientAddress4.sin_family = AF_INET;
|
clientAddress4.sin_family = AF_INET;
|
||||||
clientAddress = (struct sockaddr *) &clientAddress4;
|
client.address = (struct sockaddr *) &clientAddress4;
|
||||||
clientAddressLength = sizeof clientAddress4;
|
client.addressLength = sizeof clientAddress4;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tcp) {
|
if (tcp) {
|
||||||
@ -105,23 +106,23 @@ void server(int tcp, int ipv6) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// create sock
|
// create sock
|
||||||
serverSocket = socket(serverAddress->sa_family, socketType, socketProtocol);
|
server.handle = socket(server.address->sa_family, socketType, socketProtocol);
|
||||||
if (serverSocket == -1) {
|
if (server.handle == -1) {
|
||||||
puts("socket not created");
|
puts("socket not created");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
puts("socket created");
|
puts("socket created");
|
||||||
|
|
||||||
// bind sock
|
// bind sock
|
||||||
if (bind(serverSocket, serverAddress, serverAddressLength) < 0) {
|
if (bind(server.handle, server.address, server.addressLength) < 0) {
|
||||||
puts("bind failed");
|
puts("bind failed");
|
||||||
exit(2);
|
exit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: threads to run both at the same time
|
// TODO: threads to run both at the same time
|
||||||
if (tcp) {
|
if (tcp) {
|
||||||
tcpListen(serverSocket, clientAddress, clientAddressLength);
|
tcpListen(server.handle, client.address, client.addressLength);
|
||||||
} else {
|
} else {
|
||||||
udpListen(serverSocket, clientAddress, clientAddressLength);
|
udpListen(server.handle, client.address, client.addressLength);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
7
server.h
7
server.h
@ -14,9 +14,16 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <pthread.h>
|
||||||
|
|
||||||
#include "quote.h"
|
#include "quote.h"
|
||||||
|
|
||||||
|
struct sockinfo {
|
||||||
|
int handle;
|
||||||
|
struct sockaddr * address;
|
||||||
|
unsigned long addressLength;
|
||||||
|
};
|
||||||
|
|
||||||
void server(int tcp, int ipv6);
|
void server(int tcp, int ipv6);
|
||||||
|
|
||||||
void tcpListen(int serverSocket, struct sockaddr *clientAddress, unsigned long addressLength);
|
void tcpListen(int serverSocket, struct sockaddr *clientAddress, unsigned long addressLength);
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user