Tizen 2.1 base
[platform/upstream/gcd.git] / dispatch-1.0 / testing / dispatch_timer_bit63.c
1 /*
2  * Copyright (c) 2008-2009 Apple Inc. All rights reserved.
3  *
4  * @APPLE_APACHE_LICENSE_HEADER_START@
5  * 
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at
9  * 
10  *     http://www.apache.org/licenses/LICENSE-2.0
11  * 
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  * 
18  * @APPLE_APACHE_LICENSE_HEADER_END@
19  */
20
21 #include "config/config.h"
22
23 #include <assert.h>
24 #include <stdio.h>
25 #include <string.h>
26 #include <sys/time.h>
27
28 #include <dispatch/dispatch.h>
29
30 #include "dispatch_test.h"
31
32 //
33 // There were several bugs related to sign extension / integer overflow that
34 // were encountered during development. Create a timer whose interval has the
35 // 63rd bit of the word set to verify that it behaves correctly.
36 //
37 // The expected side-effect of integer overflow would be for the timer to
38 // fire immediately since its interval has "elapsed." If the timer does not
39 // fire within 1s we can assume the arithmetic was performed correctly.
40 //
41
42 int
43 main(void)
44 {
45         test_start("Dispatch Source Timer, bit 63");
46
47         //uint64_t interval = 0xffffffffffffffffull;
48         uint64_t interval = 0x8000000000000001ull;
49
50         dispatch_queue_t mainq = dispatch_get_main_queue();
51
52         __block int i = 0;
53         struct timeval start_time;
54
55         gettimeofday(&start_time, NULL);
56
57         dispatch_source_t ds;
58         ds = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0, mainq);
59         assert(ds);
60         dispatch_source_set_event_handler(ds, ^{
61                 assert(i < 1);
62                 printf("%d\n", i++);
63         });
64         dispatch_source_set_timer(ds, DISPATCH_TIME_NOW, interval, 0);
65         dispatch_resume(ds);
66
67         dispatch_after(dispatch_time(DISPATCH_TIME_NOW, 1*NSEC_PER_SEC),
68                 dispatch_get_main_queue(), ^{
69                 test_stop();
70         });
71
72         dispatch_main();
73
74         return 0;
75 }