summaryrefslogtreecommitdiff
path: root/lib/libc_r
diff options
context:
space:
mode:
authorDavid Leonard <d@cvs.openbsd.org>1998-12-21 07:18:37 +0000
committerDavid Leonard <d@cvs.openbsd.org>1998-12-21 07:18:37 +0000
commita0089315910b3609b141f3e965cc2ac806fcc567 (patch)
tree96346679dc8c92230b6217b1d29095572bdece71 /lib/libc_r
parent03f151fd3bdf033b52b378c56033aea57f0366ff (diff)
clean
Diffstat (limited to 'lib/libc_r')
-rw-r--r--lib/libc_r/TEST/test_sock_2a.c60
1 files changed, 29 insertions, 31 deletions
diff --git a/lib/libc_r/TEST/test_sock_2a.c b/lib/libc_r/TEST/test_sock_2a.c
index 7ff73bcfc76..649df1ae4e1 100644
--- a/lib/libc_r/TEST/test_sock_2a.c
+++ b/lib/libc_r/TEST/test_sock_2a.c
@@ -13,13 +13,17 @@
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
+#include <unistd.h>
+#include <string.h>
+#include "test.h"
struct sockaddr_in a_sout;
#define MESSAGE5 "This should be message #5"
#define MESSAGE6 "This should be message #6"
-void * sock_connect(void* arg)
+void *
+sock_connect(void* arg)
{
char buf[1024];
int fd, tmp;
@@ -28,60 +32,54 @@ void * sock_connect(void* arg)
port = 3276;
a_sout.sin_family = AF_INET;
a_sout.sin_port = htons(port);
- a_sout.sin_addr.s_addr = htonl(0x7f000001); /* loopback */
+ a_sout.sin_addr.s_addr = htonl(INADDR_LOOPBACK); /* loopback */
- if ((fd = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
- perror("Error: sock_connect:socket()");
- exit(1);
- }
+ if ((fd = socket(AF_INET, SOCK_STREAM, 0)) < 0)
+ DIE(errno, "sock_connect:socket()");
printf("This should be message #2\n");
- if (connect(fd, (struct sockaddr *) &a_sout, sizeof(a_sout)) < 0) {
- perror("Error: sock_connect:connect()");
- exit(1);
- }
+ if (connect(fd, (struct sockaddr *) &a_sout, sizeof(a_sout)) < 0)
+ DIE(errno, "sock_connect:connect()");
close(fd);
- if ((fd = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
- perror("Error: sock_connect:socket()");
- exit(1);
- }
+ if ((fd = socket(AF_INET, SOCK_STREAM, 0)) < 0)
+ DIE(errno, "sock_connect:socket()");
printf("This should be message #3\n");
- if (connect(fd, (struct sockaddr *) &a_sout, sizeof(a_sout)) < 0) {
- perror("Error: sock_connect:connect()");
- exit(1);
- }
+ if (connect(fd, (struct sockaddr *) &a_sout, sizeof(a_sout)) < 0)
+ DIE(errno, "sock_connect:connect()");
/* Ensure sock_read runs again */
- if ((tmp = read(fd, buf, 1024)) <= 0) {
- printf("Error: sock_connect:read() == %d %s\n", tmp, strerror(errno));
- exit(1);
- }
+ if ((tmp = read(fd, buf, 1024)) <= 0)
+ DIE(errno, "sock_connect:read() == %d\n", tmp);
write(fd, MESSAGE6, sizeof(MESSAGE6));
printf("%s\n", buf);
close(fd);
+
+ return (NULL);
}
+int
main(int argc, char **argv)
{
pthread_t thread;
- int i;
+ int ret;
if (argv[1] && (!strcmp(argv[1], "fork okay"))) {
sleep(1);
setbuf(stdout, NULL);
setbuf(stderr, NULL);
- if (pthread_create(&thread, NULL, sock_connect, (void *)0xdeadbeaf)) {
- perror("Error: main:pthread_create(sock_connect)");
- exit(1);
- }
- pthread_exit(NULL);
+ if ((ret = pthread_create(&thread, NULL, sock_connect,
+ (void *)0xdeadbeaf)))
+ DIE(ret, "main:pthread_create(sock_connect)");
+ pthread_join(thread, NULL);
+ exit(0);
+ } else {
+ printf("test_sock_2a needs to be execed from test_sock_2.\n");
+ printf("It is not a stand alone test.\n");
+ exit(1);
}
- printf("test_sock_2a needs to be execed from test_sock_2.\n");
- printf("It is not a stand alone test.\n");
- exit(1);
}