annotate run/cast_22.d @ 1630:d0efa3ae5522 default tip

run/mini/naked_asm5: New x86_64 ABI passes the arguments in reverse order.
author David Nadlinger <code@klickverbot.at>
date Sat, 23 Apr 2011 22:57:32 +0200
parents b8c0195059d9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
317
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
1 // $HeadURL$
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
2 // $Date$
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
3 // $Author$
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
4
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
5 // @author@ zwang <nehzgnaw@gmail.com>
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
6 // @date@ 2005-03-07
1489
b8c0195059d9 changed nntp: URLs to http: URLs
thomask
parents: 317
diff changeset
7 // @uri@ http://www.digitalmars.com/pnews/read.php?server=news.digitalmars.com&group=digitalmars.D.bugs&artnum=3104
317
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
8
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
9 module dstress.run.cast_22;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
10
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
11 uint f(){
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
12 uint r;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
13 uint* p = cast(uint*)&r;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
14 *p = 1;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
15 return r;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
16 }
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
17
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
18 uint g(){
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
19 uint r;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
20 int* p = cast(int*)&r;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
21 *p = 1;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
22 return r;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
23 }
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
24
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
25 int main(){
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
26 assert(f()==1);
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
27 assert(g()==1);
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
28 return 0;
188082b88d85 cast(uint/int)
thomask
parents:
diff changeset
29 }