4 open STDOUT,">$output";
6 $0 =~ m/(.*[\/\\])[^\/\\]+$/; $dir=$1;
9 require "uplink-common.pl";
11 local $V=8; # max number of args uplink functions may accept...
12 my $loc0 = "r".(32+$V);
15 .global OPENSSL_Uplink#
16 .type OPENSSL_Uplink#,\@function
19 for ($i=1;$i<=$N;$i++) {
24 { .mii; .save ar.pfs,$loc0
25 alloc loc0=ar.pfs,$V,3,2,0
28 addl loc2=\@ltoff(OPENSSL_UplinkTable#),gp };;
30 { .mmi; ld8 out0=[loc2]
32 { .mib; add loc2=8*$i,out0
33 br.call.sptk.many b0=OPENSSL_Uplink# };;
34 { .mmi; ld8 r31=[loc2];;
39 { .mib; mov ar.pfs=loc0
47 .global OPENSSL_UplinkTable#
48 OPENSSL_UplinkTable: data8 $N // amount of following entries
50 for ($i=1;$i<=$N;$i++) { print " data8 \@fptr(lazy$i#)\n"; }
52 .size OPENSSL_UplinkTable,.-OPENSSL_UplinkTable#