Closed
Bug 163018
Opened 22 years ago
Closed 21 years ago
Fix support for lib64 & x86-64 architectures
Categories
(Core :: JavaScript Engine, enhancement)
Tracking
()
VERIFIED
FIXED
People
(Reporter: gbeauchesne, Assigned: gbeauchesne)
References
Details
(Keywords: fixed1.4)
Attachments
(1 file, 2 obsolete files)
2.00 KB,
patch
|
netscape
:
review+
brendan
:
superreview+
asa
:
approval1.4+
|
Details | Diff | Splinter Review |
This bug report addresses two problems:
1) On lib64 architectures like x86-64 (but also ppc64 and sparc64), 64-bit
libraries got to */lib64 instead of the regular */lib directories.
2) Implement VARARGS_ASSIGN with the standard va_copy() macro on
x86-64.
Assignee | ||
Comment 1•22 years ago
|
||
Assignee | ||
Comment 2•22 years ago
|
||
Hi, I forgot to mention the patch also adds -fPIC required to build DSO on
x86-64. However, the way it's done is surely not the cleanest one.
Comment 3•22 years ago
|
||
Reassigning to Kenton; cc'ing Brendan, rginda. Note the provided patch
has some binary information at the top of the file -
Assignee: rogerl → khanson
Updated•22 years ago
|
Status: UNCONFIRMED → NEW
Ever confirmed: true
Attachment #95547 -
Attachment is patch: false
Attachment #95547 -
Attachment mime type: text/plain → application/macbinary
Updated•22 years ago
|
Attachment #95547 -
Attachment mime type: application/macbinary → text/plain
Comment 4•22 years ago
|
||
The bottom of the file looks corrupted, too. Could one of the
developers advise Gwenole on what might have gone wrong? Thanks -
Assignee | ||
Comment 5•22 years ago
|
||
Sorry, I hope it's OK this time.
Attachment #95547 -
Attachment is obsolete: true
Attachment #95547 -
Attachment mime type: text/plain → application/macbinary
Updated•22 years ago
|
Comment 6•22 years ago
|
||
line
#else /* __alpha */
should read
#else /* __alpha || __x86_64__ */
Attachment #95612 -
Flags: review?(rogerl)
Updated•22 years ago
|
Attachment #95612 -
Flags: review?(rogerl) → review?(shaver)
Comment 7•22 years ago
|
||
Comment on attachment 95612 [details] [diff] [review]
JS fixes for Linux/x86-64
r=shaver. Let's see about getting this in for 1.4b, if there's still time.
Attachment #95612 -
Flags: review?(shaver)
Attachment #95612 -
Flags: review+
Attachment #95612 -
Flags: approval1.4b?
Comment 8•22 years ago
|
||
Comment on attachment 95612 [details] [diff] [review]
JS fixes for Linux/x86-64
a=asa (on behalf of drivers) for checkin to 1.4b.
Attachment #95612 -
Flags: approval1.4b? → approval1.4b+
Attachment #95612 -
Flags: approval1.4?
Comment 9•22 years ago
|
||
Comment on attachment 95612 [details] [diff] [review]
JS fixes for Linux/x86-64
a=asa (on behalf of drivers) for checkin to 1.4
Attachment #95612 -
Flags: approval1.4? → approval1.4+
Comment 10•22 years ago
|
||
Comment on attachment 95612 [details] [diff] [review]
JS fixes for Linux/x86-64
I checked this in.
I'm sorry it missed 1.4b
the va_copy change sort of conflicted with
a change for bug 187180, please make sure
that the way i resolved it works.
Attachment #95612 -
Attachment is obsolete: true
Comment 11•22 years ago
|
||
timeless: is this ready to be marked FIXED, then?
Comment 12•22 years ago
|
||
I'm uncomfortable resolving bugs for things I can't test.
I'd rather Gwenole resolve it.
Assignee: khanson → gbeauchesne
Comment 13•22 years ago
|
||
This checkin has broken the build of the JS shell on Windows.
I get an error on WinNT4.0 on this part of the build:
link.exe kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib
advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib
oldnames.lib /nologo /subsystem:windows /dll /debug /pdb:none /machine:I386
/opt:ref /opt:noicf /base:0x61000000 fdlibm/WINNT4.0_DBG.OBJ/fdlibm.lib \
/out:"WINNT4.0_DBG.OBJ/js32.dll" /pdb:none\
/implib:"WINNT4.0_DBG.OBJ/js32.lib"
WINNT4.0_DBG.OBJ/jsapi.obj
WINNT4.0_DBG.OBJ/jsarena.obj WINNT4.0_DBG.OBJ/jsarray.obj
WINNT4.0_DBG.OBJ/jsatom.obj WINNT4.0_DBG.OBJ/jsbool.obj
WINNT4.0_DBG.OBJ/jscntxt.obj WINNT4.0_DBG.OBJ/jsdate.obj
WINNT4.0_DBG.OBJ/jsdbgapi.obj WINNT4.0_DBG.OBJ/jsdhash.obj
WINNT4.0_DBG.OBJ/jsdtoa.obj WINNT4.0_DBG.OBJ/jsemit.obj
WINNT4.0_DBG.OBJ/jsexn.obj WINNT4.0_DBG.OBJ/jsfun.obj
WINNT4.0_DBG.OBJ/jsgc.obj WINNT4.0_DBG.OBJ/jshash.obj
WINNT4.0_DBG.OBJ/jsinterp.obj WINNT4.0_DBG.OBJ/jslock.obj
WINNT4.0_DBG.OBJ/jslog2.obj WINNT4.0_DBG.OBJ/jslong.obj
WINNT4.0_DBG.OBJ/jsmath.obj WINNT4.0_DBG.OBJ/jsnum.obj
WINNT4.0_DBG.OBJ/jsobj.obj WINNT4.0_DBG.OBJ/jsopcode.obj
WINNT4.0_DBG.OBJ/jsparse.obj WINNT4.0_DBG.OBJ/jsprf.obj
WINNT4.0_DBG.OBJ/jsregexp.obj WINNT4.0_DBG.OBJ/jsscan.obj
WINNT4.0_DBG.OBJ/jsscope.obj WINNT4.0_DBG.OBJ/jsscript.obj
WINNT4.0_DBG.OBJ/jsstr.obj WINNT4.0_DBG.OBJ/jsutil.obj
WINNT4.0_DBG.OBJ/jsxdrapi.obj WINNT4.0_DBG.OBJ/prmjtime.obj
LINK : fatal error LNK1181: cannot open input file "kernel32.lib"
make[1]: *** [WINNT4.0_DBG.OBJ/js32.dll] Error 157
make: *** [all] Error 2
Comment 14•22 years ago
|
||
NOTE: I can build again if I revert js/src/config.mk from 3.10 to 3.9:
===================================================================
RCS file: /cvsroot/mozilla/js/src/config.mk,v
retrieving revision 3.10
retrieving revision 3.9
diff -r3.10 -r3.9
155,161d154
<
< # Library name
< LIB := lib
< ifeq ($(CPU_ARCH), x86_64)
< LIB := lib64
< endif
<
That was part of this checkin -
Comment 16•22 years ago
|
||
I'm thinking the JS's build scripts use of $(LIB) is ill advised. LIB is also
the list of directories used by the linker to find libraries. But it look as if
the JS build system uses to determine the directory to put libraries for
distribution.
I'm not sure what the best way to fix things are. Just remove that change, and
let the libs go into the default distribution directory as they currently are?
Or rename lib to something like LIBDIST or otherwise less conflicting.
Comment 17•22 years ago
|
||
This is blocking me from publishing the next JS1.5 release candidate -
Comment 18•22 years ago
|
||
Cc'ing bryner for a little help, if he can help.
/be
Comment 19•22 years ago
|
||
This should do the trick. Sorry I didn't see this before, but I got confused
thinking I was looking at the original code when I was looking at the code
after the patch.
Bottom line, LIB was a poor choice of a name due to the conflicts, renamed to
LIBDIR.
Comment 20•22 years ago
|
||
Comment on attachment 124127 [details] [diff] [review]
Rename LIB to LIBDIR
Looking for reviews for patch renaming LIB to LIBDIR
Attachment #124127 -
Flags: superreview?(brendan)
Attachment #124127 -
Flags: review?(seawood)
Comment 21•22 years ago
|
||
Comment on attachment 124127 [details] [diff] [review]
Rename LIB to LIBDIR
Thanks for fixing this.
/be
Attachment #124127 -
Flags: superreview?(brendan) → superreview+
Updated•22 years ago
|
Attachment #124127 -
Flags: review?(seawood) → review+
Comment 22•22 years ago
|
||
Comment on attachment 124127 [details] [diff] [review]
Rename LIB to LIBDIR
This is a no-brainer for the 1.4 branch. Dbradley, can you do the checkin
follow-thru? Thanks,
/be
Attachment #124127 -
Flags: approval1.4?
Comment 23•22 years ago
|
||
Yes, I'll get it checked in to the branch and the trunk
Comment 24•21 years ago
|
||
Comment on attachment 124127 [details] [diff] [review]
Rename LIB to LIBDIR
a=asa (on behalf of drivers) for checkin to 1.4.
Attachment #124127 -
Flags: approval1.4? → approval1.4+
Comment 25•21 years ago
|
||
LIB->LIBDIR patch checked into trunk
Comment 26•21 years ago
|
||
The new fix has enabled me to build the JS shell on Windows again!
Both the debug and optimized shell built sucessfully.
Furthermore, I ran the JS testsuite against the fix on Linux RH7.2,
Mac OSX, and WinNT4.0 and observed no test regresssions in either
the debug or optimized JS shell -
Comment 27•21 years ago
|
||
I tried checking into the 1.4 branch, but I don't have access. So if someone
else can check this in, that would be great, or if I get access soon I'll go
ahead and do it.
Comment 28•21 years ago
|
||
LIB->LIBDIR patch checked into branch now.
Status: NEW → RESOLVED
Closed: 21 years ago
Resolution: --- → FIXED
Updated•21 years ago
|
Flags: blocking1.4?
Comment 30•21 years ago
|
||
Adding verified1.4 keyword. That is, I have verified that the patches
to these files are the same on the trunk and the -rMOZILLA_1_4_BRANCH:
js/src/config.mk
js/src/jsconfig.mk
js/src/rules.mk
The patch to the following config file is only on the trunk, however.
That is normal, since it is only used in the build of the standalone
JS shell:
js/src/config/Linux_All.mk
In fact, AFAIK, the directory mozilla/js/src/config/ is never
tagged in Mozilla branches -
Keywords: verified1.4
Updated•19 years ago
|
Flags: testcase-
You need to log in
before you can comment on or make changes to this bug.
Description
•