[OpenBIOS] [PATCH] ppc: fix ESCC reg properties

Programmingkid programmingkidx at gmail.com
Wed Feb 3 18:00:48 CET 2016


On Feb 3, 2016, at 1:29 AM, Hervé Poussineau wrote:

> I/O offsets were wrong in legacy mode and some were missing in non-legacy mode.
> This fixes serial port detection in NetBSD, which was ignoring it.
> This also partly fixes MacOS 9.2, which relies on them to initialize OpenTransport.
> 
> Signed-off-by: Hervé Poussineau <hpoussin at reactos.org>
> ---
> drivers/escc.c | 22 ++++++++++++----------
> 1 file changed, 12 insertions(+), 10 deletions(-)
> 
> diff --git a/drivers/escc.c b/drivers/escc.c
> index afb97fa..8f122d8 100644
> --- a/drivers/escc.c
> +++ b/drivers/escc.c
> @@ -384,6 +384,8 @@ escc_add_channel(const char *path, const char *node, phys_addr_t addr,
> {
>     char buf[64], tty[32];
>     phandle_t dnode, aliases;
> +    int legacy_offsets[][3] = { { 0x4, 0x6, 0xa }, { 0x0, 0x2, 0x8 } };
> +    int offsets[][3] = { { 0x20, 0x30, 0x50 }, { 0x00, 0x10, 0x40 } };
> 
>     cell props[10];
>     int offset;
> @@ -425,18 +427,18 @@ escc_add_channel(const char *path, const char *node, phys_addr_t addr,
>     set_property(dnode, "compatible", buf, 9);
> 
>     if (legacy) {
> -        props[0] = IO_ESCC_LEGACY_OFFSET + offset * 0x4;
> -        props[1] = 0x00000001;
> -        props[2] = IO_ESCC_LEGACY_OFFSET + offset * 0x4 + 2;
> -        props[3] = 0x00000001;
> -        props[4] = IO_ESCC_LEGACY_OFFSET + offset * 0x4 + 6;
> -        props[5] = 0x00000001;
> -        set_property(dnode, "reg", (char *)&props, 6 * sizeof(cell));
> +        props[0] = IO_ESCC_LEGACY_OFFSET + legacy_offsets[offset][0];
> +        props[2] = IO_ESCC_LEGACY_OFFSET + legacy_offsets[offset][1];
> +        props[4] = IO_ESCC_LEGACY_OFFSET + legacy_offsets[offset][2];
>     } else {
> -        props[0] = IO_ESCC_OFFSET + offset * 0x20;
> -        props[1] = 0x00000020;
> -        set_property(dnode, "reg", (char *)&props, 2 * sizeof(cell));
> +        props[0] = IO_ESCC_LEGACY_OFFSET + offsets[offset][0];
> +        props[2] = IO_ESCC_LEGACY_OFFSET + offsets[offset][1];
> +        props[4] = IO_ESCC_LEGACY_OFFSET + offsets[offset][2];
>     }
> +    props[1] = 0x00000001;
> +    props[3] = 0x00000001;
> +    props[5] = 0x00000001;
> +    set_property(dnode, "reg", (char *)&props, 6 * sizeof(cell));
> 
>     if (legacy) {
>         props[0] = addr + IO_ESCC_LEGACY_OFFSET + offset * 0x4;
> -- 
> 2.1.4
> 

I didn't notice anything different when I tried booting Mac OS 9.2 with and without your patch. Mac OS 9.2 always crashes on startup for me. What changes did you notice while using Mac OS 9 with your patch?


More information about the OpenBIOS mailing list