Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 26 Jun 2008 23:52:38 +0200
From:      Roland Smith <rsmith@xs4all.nl>
To:        Erik Trulsson <ertr1013@student.uu.se>
Cc:        Kris Kennaway <kris@freebsd.org>, Tim Daneliuk <tundra@tundraware.com>, FreeBSD Mailing List <freebsd-questions@freebsd.org>
Subject:   Re: Making World For amd64
Message-ID:  <20080626215238.GA5666@slackbox.xs4all.nl>
In-Reply-To: <20080626211915.GA65600@owl.midgard.homeip.net>
References:  <4863F317.6010701@tundraware.com> <4863F4A7.1070909@FreeBSD.org> <4863F5A3.6050209@tundraware.com> <4863FC2A.5040909@FreeBSD.org> <4864015C.7010805@tundraware.com> <20080626211915.GA65600@owl.midgard.homeip.net>

next in thread | previous in thread | raw e-mail | index | archive | help

--HlL+5n6rz5pIUxbD
Content-Type: text/plain; charset=us-ascii
Content-Disposition: inline
Content-Transfer-Encoding: quoted-printable

On Thu, Jun 26, 2008 at 11:19:15PM +0200, Erik Trulsson wrote:
> On Thu, Jun 26, 2008 at 03:51:40PM -0500, Tim Daneliuk wrote:
> > Kris Kennaway wrote:
> > > Tim Daneliuk wrote:
> > >> Kris Kennaway wrote:
> > >>> Tim Daneliuk wrote:
> > >>>> Is there anything special one has to do when doing a make world
> > >>>> intended for 64-bit FreeBSD or is it sufficient to build the 64-bit
> > >>>> kernel and make world as everywhere else?
> > >>> The same as everywhere else.
> > >>>
> > >>> Kris
> > >>
> > >> So, I take it that this means that all the userspace programs, ports,
> > >> packages, utilities, etc. do *not* take advantage of the 64-bit
> > >> extensions.  That is, only the kernel gets the benefit of the
> > >> wider word.  Is that correct?
> > >>
> > >=20
> > > No, everything is 100% native.
> > >=20
> > > Kris
> > >=20
> >=20
> > OK, these may be really stupid questions but:
> >=20
> > 1) How does make world know whether to build 32-bit or 64-bit binaries?
>=20
> It will build for whatever system you have installed.

The system Makefile calls 'uname -p' to get the system's processor
architecture.=20

> If you are running a 32-bit system it will make 32-bit binaries, and if
> you are running a 64-bit system it will make 64-bit binaries.

By default, amd64 also builds 32-bit libraries (/usr/lib32), unless you
set WITHOUT_LIB32=3Dtrue in /etc/src.conf.=20

> > 2) Can a binary from a 32-bit FreeBSD system be run unmodified on the
> >   64-bit system?
>=20
> Assuming the 32-bit system is 'i386' and the 64-bit system is 'amd64' then
> you are supposed to be able to do so=20

You will need a kernel (such as GENERIC) built with 'options COMPAT_IA32'.

>(but I don't know how well it works in
> practice).  Otherwise no.  (Running a i386 binary on a sparc64 system won=
't
> work.)

You will also need all the libraries that the application depends on in
32-bit versions. Either by copying them from a 32-bit system (built from
the same source version) or by doing a cross-build.

There was a thread some time ago (not sure if it was in -questions or
-amd64) about using a 32-bit jail on amd64. That might be of interest.

> > 3) If I reboot with 32-bit or 64-bit kernels, does the system magically
> >    somehow make the userland stuff work natively at the word width?
> >    If so, how?
>=20
> If you have installed the amd64 variant of FreeBSD (for example) then
> all binaries (userland and kernel alike) will have been compiled for
> the amd64 architecture (and thus 64-bit.)  If you are running the i386
> variant then all binaries will have been compiled for i386 (and thus
> 32-bit.)

You can have both 32-bit and 64-bit systems on one machine, provided you
put them on separate slices/partitions. Obviously you cannot have both a
32-bit and a 64-bit version of e.g. /bin/sh on one partition.

Roland
--=20
R.F.Smith                                   http://www.xs4all.nl/~rsmith/
[plain text _non-HTML_ PGP/GnuPG encrypted/signed email much appreciated]
pgp: 1A2B 477F 9970 BA3C 2914  B7CE 1277 EFB0 C321 A725 (KeyID: C321A725)

--HlL+5n6rz5pIUxbD
Content-Type: application/pgp-signature
Content-Disposition: inline

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v2.0.9 (FreeBSD)

iEYEARECAAYFAkhkD6YACgkQEnfvsMMhpyUwowCgnEqnuTOTn/hHAuyhAPo70Tpx
zU0AnA+1eljzIh07iIf4iAP8/MQ2ma7t
=3wo/
-----END PGP SIGNATURE-----

--HlL+5n6rz5pIUxbD--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20080626215238.GA5666>