Date: Tue, 05 Jun 2001 07:59:01 +0200 From: Poul-Henning Kamp <phk@critter.freebsd.dk> To: Jim Pirzyk <Jim.Pirzyk@disney.com> Cc: freebsd-arch@FreeBSD.ORG Subject: Re: sysctl interger type max Message-ID: <65709.991720741@critter> In-Reply-To: Your message of "Mon, 04 Jun 2001 12:49:14 PDT." <01060412491406.00744@snoopy>
next in thread | previous in thread | raw e-mail | index | archive | help
In message <01060412491406.00744@snoopy>, Jim Pirzyk writes:
>On Monday 04 June 2001 12:43 pm, Poul-Henning Kamp wrote:
>> In message <01060412361804.00744@snoopy>, Jim Pirzyk writes:
>> >On Monday 04 June 2001 12:26 pm, Poul-Henning Kamp wrote:
>> >> In message <01060412242703.00744@snoopy>, Jim Pirzyk writes:
>> >> >In sysctl(8), you can set an integer type, but the max value
>> >> >an int can be is 2 * N-1 where N is the size of int. This leads
>> >> >to a problem when trying to set kern.hostid and the number is
>> >> >greater that 2GB on an IA32 system. So my question is should
>> >> >CTLTYPE_INT be treated as a long or some other larger numeric
>> >> >number? Or should we declare some CLTYPE_UINT type?
>> >>
>> >> We do have an SYSCTL_UINT these days.
>> >
>> >Yes for establishing the oid in the kernel, but sysctl command
>> >line is limited to 2 * 31 bits even if the variable is set to
>> >CLTYPE_{UINT|LONG|ULONG}. This means you cannot set the variables
>> >to a possible range of values.
>>
>> Then sysctl(8) is obviously broken...
>
>Yes, so how should it be fixed? Add another CTLTYPE_* or make
>CTLTYPE_INT handle say up to 'long long'?
CTLTYPE_UINT should be fixed in sysctl(8) to handle [0..2^32-1]
--
Poul-Henning Kamp | UNIX since Zilog Zeus 3.20
phk@FreeBSD.ORG | TCP/IP since RFC 956
FreeBSD committer | BSD since 4.3-tahoe
Never attribute to malice what can adequately be explained by incompetence.
To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-arch" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?65709.991720741>
