Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(334)

Side by Side Diff: tests/test_syscalls.cc

Issue 7326013: GCC 4.6 warnings cleanup (Closed) Base URL: http://seccompsandbox.googlecode.com/svn/trunk/
Patch Set: Created 9 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « socketcall.cc ('k') | x86_decode.cc » ('j') | x86_decode.cc » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include <asm/unistd.h> 5 #include <asm/unistd.h>
6 #include <dirent.h> 6 #include <dirent.h>
7 #include <errno.h> 7 #include <errno.h>
8 #include <poll.h> 8 #include <poll.h>
9 #include <pthread.h> 9 #include <pthread.h>
10 #include <pty.h> 10 #include <pty.h>
(...skipping 1221 matching lines...) Expand 10 before | Expand all | Expand 10 after
1232 // This tests that blocking on recvmsg() in one thread does not 1232 // This tests that blocking on recvmsg() in one thread does not
1233 // produce a deadlock if another thread attempts to do sendmsg() to 1233 // produce a deadlock if another thread attempts to do sendmsg() to
1234 // send a message that the first thread is waiting for. The trusted 1234 // send a message that the first thread is waiting for. The trusted
1235 // process should not wait for recvmsg() to finish before processing 1235 // process should not wait for recvmsg() to finish before processing
1236 // more system calls. 1236 // more system calls.
1237 StartSeccompSandbox(); 1237 StartSeccompSandbox();
1238 1238
1239 int sock_pair[2]; 1239 int sock_pair[2];
1240 CHECK_SUCCEEDS(socketpair(AF_UNIX, SOCK_STREAM, 0, sock_pair) == 0); 1240 CHECK_SUCCEEDS(socketpair(AF_UNIX, SOCK_STREAM, 0, sock_pair) == 0);
1241 pthread_t tid; 1241 pthread_t tid;
1242 int err = pthread_create(&tid, NULL, recvmsg_thread, (void *) sock_pair[0]); 1242 int err = pthread_create(&tid, NULL, recvmsg_thread,
1243 reinterpret_cast<void*>(sock_pair[0]));
1243 CHECK(err == 0); 1244 CHECK(err == 0);
1244 1245
1245 // In order to test for the deadlock, we need to wait for the child 1246 // In order to test for the deadlock, we need to wait for the child
1246 // thread to run long enough to block in recvmsg(). Unfortunately, 1247 // thread to run long enough to block in recvmsg(). Unfortunately,
1247 // there is no way to wait until another thread is blocked, so we 1248 // there is no way to wait until another thread is blocked, so we
1248 // need to use a sleep. No value is correct here: On a heavily 1249 // need to use a sleep. No value is correct here: On a heavily
1249 // loaded machine, the child thread might not get scheduled in time. 1250 // loaded machine, the child thread might not get scheduled in time.
1250 // We pick a sleep time that is respectably large without slowing 1251 // We pick a sleep time that is respectably large without slowing
1251 // the tests down too much. 1252 // the tests down too much.
1252 CHECK_SUCCEEDS(poll(NULL, 0, 200) == 0); 1253 CHECK_SUCCEEDS(poll(NULL, 0, 200) == 0);
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after
1383 if (failures == 0) { 1384 if (failures == 0) {
1384 printf("OK\n"); 1385 printf("OK\n");
1385 return 0; 1386 return 0;
1386 } 1387 }
1387 else { 1388 else {
1388 printf("%i FAILURE(S)\n", failures); 1389 printf("%i FAILURE(S)\n", failures);
1389 return 1; 1390 return 1;
1390 } 1391 }
1391 } 1392 }
1392 } 1393 }
OLDNEW
« no previous file with comments | « socketcall.cc ('k') | x86_decode.cc » ('j') | x86_decode.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698