WARNING - OLD ARCHIVES

This is an archived copy of the Xen.org mailing list, which we have preserved to ensure that existing links to archives are not broken. The live archive, which contains the latest emails, can be found at http://lists.xen.org/
   
 
 
Xen 
 
Home Products Support Community News
 
   
 

xen-ppc-devel

Re: [XenPPC] [Patch] Find serial device and platform type

To: Maria Butrico <butrico@xxxxxxxxxxxxxx>
Subject: Re: [XenPPC] [Patch] Find serial device and platform type
From: Hollis Blanchard <hollisb@xxxxxxxxxx>
Date: Mon, 24 Apr 2006 11:37:09 -0500
Cc: xen-ppc-devel@xxxxxxxxxxxxxxxxxxx
Delivery-date: Mon, 24 Apr 2006 09:36:15 -0700
Envelope-to: www-data@xxxxxxxxxxxxxxxxxx
In-reply-to: <E1FWwwp-0001Vm-Ud@xxxxxxxxxxxxxxxxxxxxx>
List-help: <mailto:xen-ppc-devel-request@lists.xensource.com?subject=help>
List-id: Xen PPC development <xen-ppc-devel.lists.xensource.com>
List-post: <mailto:xen-ppc-devel@lists.xensource.com>
List-subscribe: <http://lists.xensource.com/cgi-bin/mailman/listinfo/xen-ppc-devel>, <mailto:xen-ppc-devel-request@lists.xensource.com?subject=subscribe>
List-unsubscribe: <http://lists.xensource.com/cgi-bin/mailman/listinfo/xen-ppc-devel>, <mailto:xen-ppc-devel-request@lists.xensource.com?subject=unsubscribe>
Organization: IBM Linux Technology Center
References: <E1FWwwp-0001Vm-Ud@xxxxxxxxxxxxxxxxxxxxx>
Sender: xen-ppc-devel-bounces@xxxxxxxxxxxxxxxxxxx
Hi Maria, you didn't include any description with your patch, so I'm not
sure if you intend it for submission or as a request for comments.

Stylistically, there are some typos, some renaming needed, some
formatting (e.g. "if (foo) bar" all on one line), // comments, lack of
punctuation in printf messages, etc. Also, the boot_of_serial() function
is waaay too long, with structs and unions defined in the middle of
it...

Also, it seems you haven't addressed any of the comments I made about
your earlier patch.

More generally, I'm not clear on why we need constants like
PMAC_HARDWARE at all (yes, I know Jimi suggested them). Why not
something like this:

----- setup.c -----
struct platform {
        char *compat;
        int (*init)(void);
} platforms = {
        { .compat = "Power Macintosh", .init = pmac_init },
        { .compat = "Momentum,Maple", .init = maple_init },

boot_of_platform() {
        for platform in platforms {
                if (compatible(platform.compat)
                        && platform.init() == SUCCESS)
                break;
        }
}

------ pmac.c -----
pmac_init() {
        zilog_register();
        return SUCCESS;
}

----- zilog.c -----
struct zilog_port {
        whatever;
} port;

zilog_register() {
        serial_register_uart(0, zilog_driver, &port)
}

-- 
Hollis Blanchard
IBM Linux Technology Center


_______________________________________________
Xen-ppc-devel mailing list
Xen-ppc-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-ppc-devel