Runtime check for PAE option on BSD 6+ i386
Philip Soeberg
philip-freebsd1 at soeberg.net
Wed May 4 11:29:25 UTC 2011
On 03-05-2011 19:43, Kostik Belousov wrote:
> On Tue, May 03, 2011 at 11:44:32AM -0400, John Baldwin wrote:
>> On Tuesday, May 03, 2011 9:10:26 am Philip Soeberg wrote:
>>> Hi fellow FreeBSD hackers,
>>>
>>> I've been using the following poor-man's approach in my driver init for
>>> ages in an attempt at detecting PAE option on BSD 6 (or greater) i386
>>> kernels, as I depend on dmabus(9) but provide a loadable kernel module only.
>>>
>>> >>>
>>> if (sizeof(void*) == 4) {
>>> if (((uint64_t)(cnt.v_page_count * cnt.v_page_size) / 1073741824)
>>> >= 4) {
>>> printf("FreeBSD i386 detected with PAE option enabled. FreeBSD
>>> PAE type\n");
>>> printf("kernels does not support loadable modules which use DMA.
>>> Please\n");
>>> printf("reconfigure your kernel for non-PAE or switch to amd64
>>> kernel.\n");
>>> return EFAULT;
>>> }
>>> }
>>> <<<
>> Hmmm, even this isn't really accurate as some folks may choose to enable PAE
>> even with< 4GB to get PG_NX functionality.
>>
>>> afaik there's a sysctl method of checking this per BSD7 (or is it 8?),
>>> but what about BSD6? Any hints on how I can runtime detect the above?
>> Definitely a kern.features.pae sysctl in 7. I don't see anything similar in
>> 6.
> Read %cr4 and test the bit there.
Ha, as always there exist a simple elegant solution.. thanks, that
method had escaped me.
More information about the freebsd-hackers
mailing list