Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 11 Mar 2015 17:34:13 -0700
From:      Mark Millard <markmi@dsl-only.net>
To:        FreeBSD PowerPC ML <freebsd-ppc@freebsd.org>, Nathan Whitehorn <nwhitehorn@freebsd.org>
Subject:   Re: 11.0-CURRENT: ofw_standard.c:175 (for example): attempts to cast char* to cell_t fail in cross compile from powerpc to powerpc64
Message-ID:  <AB1C37A6-0CD1-454B-A6DE-D2D4D487E373@dsl-only.net>
In-Reply-To: <F424563F-14D0-4F3C-B026-B7154B513A9D@dsl-only.net>
References:  <F424563F-14D0-4F3C-B026-B7154B513A9D@dsl-only.net>

next in thread | previous in thread | raw e-mail | index | archive | help
Given the mix of the new relocatable kernels, powerpc64 (and other > 32 =
bit-bit addressed openfirmware use?) and "typedef uint32_t cell_t;" (at =
least for sys/powerpc/include/ofw_machdep.h)...

For the char*-to-cell_t casing in 11.0-CURRENT's ofw_standard.c to work =
for powerpc64 and others with larger than 32 bit addresses but =
restrictions in the openfirmware implementation it would seem that =
something must force the strings to stay in lower memory where zero =
extended 32 bit values work as addresses. (Which may well be a =
requirement of the Openfirmware implementation --no matter how things =
are expressed in C/C++ code.)

On fundamentals it looks to me like the 11.0-CURRENT ofw_standard.c code =
assumes that only a <=3D 32 bit pointer environment would be using =
openfirmware: I see no hook for keeping the relevant strings inside the =
smaller address range.


=3D=3D=3D
Mark Millard
markmi at dsl-only.net

On 2015-Mar-11, at 05:12 PM, Mark Millard <markmi at dsl-only.net> =
wrote:

Basic context (on a PowerMac G5 but using a powerpc 11.0-CURRENT build =
to cross build targeting powerpc64):

# freebsd-version -ku; uname -a
11.0-CURRENT
11.0-CURRENT
FreeBSD FBSDG4C0 11.0-CURRENT FreeBSD 11.0-CURRENT #0 r279514M: Mon Mar  =
9 22:24:27 PDT 2015     =
root@FBSDG4S0:/usr/obj/usr/srcC/sys/GENERICvtsc-NODEBUG  powerpc
# svnlite info
Path: .
Working Copy Root Path: /usr/srcC
URL: https://svn0.us-west.freebsd.org/base/head
Relative URL: ^/head
Repository Root: https://svn0.us-west.freebsd.org/base
Repository UUID: ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f
Revision: 279514
Node Kind: directory
Schedule: normal
Last Changed Author: adrian
Last Changed Rev: 279514
Last Changed Date: 2015-03-01 18:27:25 -0800 (Sun, 01 Mar 2015)


The problem for building powerpc64 kernels from a powerpc build's =
context...

I tried to buildworld buildkernel with TARGET=3Dpowerpc =
TARGET_ARCH=3Dpowerpc64. while buildworld completed buildkernel did not.

I give the relevant part of the script output file below but the basic =
problem shows up as point to integer conversions with mismatched sizes =
in code casting (for example) char* to cell_t such as:

static int
ofw_std_test(ofw_t ofw, const char *name)
{
       struct {
               cell_t name;
               cell_t nargs;
               cell_t nreturns;
               cell_t service;
               cell_t missing;
       } args =3D {
               (cell_t)"test", // <<<<<<<<<< LOOK HERE
               1,
               1,
       };

       args.service =3D (cell_t)name; // <<<<<<<<<< LOOK HERE
       if (openfirmware(&args) =3D=3D -1)
               return (-1);
       return (args.missing);
}


The script log shows:

...
ctfconvert -L VERSION -g ofwbus.o^M
cc  -c -O -pipe  -g -Wall -Wredundant-decls -Wnested-externs =
-Wstrict-prototypes  -Wmissing-prototypes -Wpointer-arith -Winline =
-Wcast-qual  -Wundef -Wno-pointer-sign -fformat-extensions  -Wmissing-in
clude-dirs -fdiagnostics-show-option  -Wno-unknown-pragmas  =
-Wno-uninitialized -nostdinc  -I. -I/usr/srcC/sys =
-I/usr/srcC/sys/contrib/altq -I/usr/srcC/sys/contrib/libfdt -D_KERNEL =
-DHAVE_KERNEL_OPTION
_HEADERS -include opt_global.h  -msoft-float -Wa,-many =
-fno-omit-frame-pointer -mno-altivec -ffreestanding -fwrapv =
-fstack-protector -gdwarf-2 -Wno-uninitialized -Wall -Wredundant-decls =
-Wnested-exter
ns -Wstrict-prototypes  -Wmissing-prototypes -Wpointer-arith -Winline =
-Wcast-qual  -Wundef -Wno-pointer-sign -fformat-extensions  =
-Wmissing-include-dirs -fdiagnostics-show-option  -Wno-unknown-pragmas
 -Wno-uninitialized  -fno-common -fms-extensions -finline-limit=3D15000 =
--param inline-unit-growth=3D100 --param large-function-growth=3D1000 =
-msoft-float  -std=3Diso9899:1999 -Werror  /usr/srcC/sys/dev/ofw/
ofw_standard.c^M
cc1: warnings being treated as errors^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_test':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:175: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:180: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_interpret':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:195: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:202: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_peer':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:226: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_child':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:248: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_parent':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:270: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function =
'ofw_std_instance_to_package':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:292: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function =
'ofw_std_getproplen':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:315: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:321: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_getprop':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:342: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:348: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:349: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_nextprop':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:370: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:376: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:377: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_setprop':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:399: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:405: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:406: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_canon':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:426: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:431: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:432: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function =
'ofw_std_finddevice':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:450: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:455: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function =
'ofw_std_instance_to_path':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:474: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:480: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function =
'ofw_std_package_to_path':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:500: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:506: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function =
'ofw_std_call_method':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:526: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:537: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_open':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:567: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:572: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_close':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:588: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_read':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:610: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:616: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_write':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:637: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:643: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_seek':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:663: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_claim':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:693: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:698: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:703: warning: cast to pointer from =
integer of different size [-Wint-to-pointer-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_release':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:717: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:722: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_enter':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:740: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
/usr/srcC/sys/dev/ofw/ofw_standard.c: In function 'ofw_std_exit':^M
/usr/srcC/sys/dev/ofw/ofw_standard.c:758: warning: cast from pointer to =
integer of different size [-Wpointer-to-int-cast]^M
*** Error code 1^M
^M
Stop.^M
make[2]: stopped in =
/usr/obj/powerpc.powerpc64/usr/srcC/sys/GENERICvtsc-NODEBUG^M
*** Error code 1^M
^M
Stop.^M
make[1]: stopped in /usr/srcC^M
*** Error code 1^M


=3D=3D=3D
Mark Millard
markmi at dsl-only.net





Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?AB1C37A6-0CD1-454B-A6DE-D2D4D487E373>