Mark Morgan Lloyd wrote:
Jonas Maebe wrote:
On 01 Mar 2010, at 15:10, Mark Morgan Lloyd wrote:

I'm still getting a bus or alignment error in the fp IDE when driving gdb but I'm reasonably optimistic that I'll be able to find that now. PowerPC is fine so it's probably not something like an endianness issue.

A bus error generally means an alignment issue. Most PowerPC processors don't require data to be aligned, but SPARC cpu's do.

Thanks for that Jonas, noted. The other possibility is some peculiarity when parsing gdb output back into the IDE. I'll be back :-)

I found myself wondering whether the problem was related to the change from NPTL to pthreads, and couldn't decide from my notes exactly when I last had the IDE debugger working successfully on SPARC. At that point I decided that trying a version of libgdb later than 6.7 would be a good idea, since this could be a libgdb rather than an fp problem.

Since I see related discussion on Mantis as 15272 I hope this will be useful to somebody.

I've got 2.5.1 installed as the standard fpc on the system I'm working on, so there's no significant difference between the installed compiler and the one I'm trying to build.

I was not able to get libgdb 6.8 working due to duplicate symbols so I moved straight to 7.0.1.

libgdb configure/make runs without problems. I note here that --without-python is inoperative and --with-python=no little better: libpython is still required even if Python scripting is not built into the debugger. The result of this is that there must be (a symlink to) libpython.so or possibly libpython.a on the target system, on Debian "Lenny" I added libpython.so -> libpython2.5.so.

These are the libgdb files that are needed for the fp IDE:

libgdb/linux/libgdb.a
libgdb/linux/libbfd.a
libgdb/linux/libopcodes.a
libgdb/linux/libiberty.a
libgdb/linux/libreadline.a
libgdb/linux/libhistory.a
libgdb/linux/libdecnumber.a
libgdb/linux/libgnu.a

Note the last two which are new. On a SPARC target they need to be in ../libgdb/linux/sparc, otherwise as above; a (Linux) PowerPC system also needs libsim.a.

With the files available as above a complete build (i.e. make all) will still fail. Referring to instructions given in bug #15272, cd fpcsrc/ide, run make 'FPCOPT=-s' and then edit link.res to add a couple more libraries:

INPUT(
-ldecnumber
-lgnu
-lz
-lexpat

Finally, run ./ppas.sh which should result in a usable 2.5.1 fp IDE with libgdb 7.0.1.

Unfortunately I still get problems on SPARC even with 7.0.1, I can't shed any light on those yet but wanted to get the above written up while it was still fresh in my mind.

--
Mark Morgan Lloyd
markMLl .AT. telemetry.co .DOT. uk

[Opinions above are the author's, not those of his employers or colleagues]
_______________________________________________
fpc-devel maillist  -  fpc-devel@lists.freepascal.org
http://lists.freepascal.org/mailman/listinfo/fpc-devel

Reply via email to