* mkimport: Specify .text for stub explicitly.

* speclib: Add a dummy '.idata$7' section referring to the dll associated with
the real import library.
This commit is contained in:
Christopher Faylor 2009-04-18 17:23:45 +00:00
parent 855762d6f4
commit b978c43ea0
3 changed files with 36 additions and 7 deletions

View File

@ -1,3 +1,9 @@
2009-04-18 Christopher Faylor <me+cygwin@cgf.cx>
* mkimport: Specify .text for stub explicitly.
* speclib: Add a dummy '.idata$7' section referring to the dll
associated with the real import library.
2009-04-18 Corinna Vinschen <corinna@vinschen.de>
* dcrt0.cc (globify): Only call mbtowc for non-ascii chars.

View File

@ -54,6 +54,7 @@ for my $f (keys %text) {
$text{$f} = 1;
open my $as_fd, '|-', $as, '-o', "$dir/t-$f", "-";
print $as_fd <<EOF;
.text
.extern $imp_sym
.global $glob_sym
$glob_sym:

View File

@ -19,6 +19,8 @@ $_ = File::Spec->rel2abs($_) for @ARGV;
my $libdll = shift;
my $lib = pop;
(my $iname = basename $lib) =~ s/\.a$//o;
$iname = '_' . $iname . '_dll_iname';
open my $nm_fd, '-|', $nm, '-Apg', '--defined-only', @ARGV, $libdll or
die "$0: execution of $nm for object files failed - $!\n";
@ -29,8 +31,12 @@ my $lastfn;
my %extract = ();
my $exclude_regex = @exclude ? join('|', @exclude) : '\\UnLiKeLy//';
$exclude_regex = qr/$exclude_regex/;
my $dllname;
while (<$nm_fd>) {
study;
if (/ I _(.*)_dll_iname/o) {
$dllname ||= $1;
} else {
my ($file, $member, $symbol) = m%^([^:]*):([^:]*(?=:))?.* T (.*)%o;
next if !defined($symbol) || $symbol =~ $exclude_regex;
if ($file ne $libdll) {
@ -39,8 +45,10 @@ while (<$nm_fd>) {
$extract{$member} = 1;
}
}
}
close $nm_fd;
%extract or die "$0: couldn't find symbols for $lib\n";
my $dir = tempdir(CLEANUP => 1);
@ -50,6 +58,20 @@ chdir $dir;
my $res = system $ar, 'x', $libdll, sort keys %extract;
die "$0: $ar extraction exited with non-zero status\n" if $res;
unlink $lib;
# Add a dummy .idata object for libtool so that it will think
# this library is an import library.
my $iname_o = 'd000000.o';
$extract{$iname_o} = 1;
open my $as_fd, '|-', $as, '-R', '-o', $iname_o, "-";
print $as_fd <<EOF;
.section .idata\$7
.global $iname
$iname: .asciz "$dllname.dll"
EOF
close $as_fd or exit 1;
system $objcopy, '-j', '.idata$7', $iname_o;
$res = system $ar, 'crus', $lib, sort keys %extract;
unlink keys %extract;
die "$0: ar creation of $lib exited with non-zero status\n" if $res;