Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 1 Jul 2008 23:30:05 +0200
From:      "Alexey Shuvaev" <shuvaev@physik.uni-wuerzburg.de>
To:        Marcel Moolenaar <xcllnt@mac.com>
Cc:        freebsd-current@freebsd.org
Subject:   Re: puc(4) man page update?
Message-ID:  <20080701213005.GA94030@wep4017.physik.uni-wuerzburg.de>
In-Reply-To: <EFBC6852-012F-4207-A4CE-B407CF92F25E@mac.com>
References:  <20080701181358.GA93601@wep4017.physik.uni-wuerzburg.de> <EFBC6852-012F-4207-A4CE-B407CF92F25E@mac.com>

next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, Jul 01, 2008 at 01:02:32PM -0700, Marcel Moolenaar wrote:
>
> On Jul 1, 2008, at 11:13 AM, Alexey Shuvaev wrote:
>
>> - I have spent few hours figuring out why serial interfaces
>>  covered by puc(4) do not come up at boot time. The issue was I tried
>>  to use kernel module instead of compiling puc(4) into the kernel.
>>  Will it be good to have explicit note about it in the man page?
>
> Well, no. There's a very simple rule:
>
> If driver C is a child of a driver P and driver P is
> loaded as a module, then driver C must be loaded as
> a module as well.
>
> In this case uart(4) and ppc(4) are children of puc(4)
> and both are compiled into the kernel by default. So,
> you must either compile puc(4) into the kernel or
> build uart(4) and puc(4) as modules as well.
>
> In other words: there's no problem with puc(4) being
> loaded as a module. It's a generic problem with our
> modules vs. compiled-in case.
>
Ok, clear now. The GENERIC kernel contains both sio(4) and uart(4)
but not the puc(4). In this sense it is "wrong" (which is the cost for
removing rarely used puc(4) out of the GENERIC kernel).

>> - First time when I rebuilt the kernel I only added
>>  options COM_MULTIPORT, which is used inside sio(4). The puc(4) also  
>> states
>>  the serial ports are managed by sio(4). However it seems that serial
>>  ports are actually handled by uart(4). Is COM_MULTIPORT kernel option
>>  obsolete?
>
> COM_MULTIPORT is specific to sio(4), so yes it's obsolete.
>
> puc(4) favors uart(4) over sio(4), because both puc(4) and
> uart(4) implement the serdev I/F, which gives puc(4) better
> control over which port gets to service what interrupt
> condition in what relative order. In other words, it allows
> puc(4) to handle all receive interrupts of all ports before
> it handles any transmit interrupts.
>
> With sio(4) there's no benefit.
>
So, one can still use puc(4) + sio(4) (by removing, for example,
uart(4) from the kernel)? Then COM_MULTIPORT is not 100% obsolete yet.

>> Attached is a draft of a patch to share/man/man4/puc.4 but maybe more
>> work is required (regarding COM_MULTIPORT and sio(4) man page...).
>
> I would not mention COM_MULTIPORT in the puc(4) manpage
> at all. Neither sio(4)...
>
I thougt about removing COM_MULTIPORT from the sio(4) both man page
and source code. If one can still use it, let it be so.

>> - The puc(4) man page states parallel ports are not supported yet.
>>  It seems thay did now.
>
> Parallel ports are supported, yes.
>
That's good!

Attached is updated patch to puc man page.
Don't know if it is really worthwhile.

Thanks,
Alexey.



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