Date: Wed, 1 Jun 2011 14:21:30 -0400 From: Attilio Rao <attilio@freebsd.org> To: freebsd-current@freebsd.org Cc: Marius Strobl <marius@freebsd.org>, Sergey Kandaurov <pluknet@freebsd.org>, Nick Esborn <nick@desert.net>, Sean Bruno <seanbru@yahoo-inc.com> Subject: [PATCH] Add the infrastructure for supporting an infinite number of CPUs Message-ID: <BANLkTi=xgP64i2S=SE1zz-p07b7cTA06Zg@mail.gmail.com>
next in thread | raw e-mail | index | archive | help
Current maximum number of CPUs supported by the FreeBSD kernel is 32. That number cames from indirectly by the fact that we have a cpumask_t type, representing a mask of CPUs, which is an unsigned int right now. I then made a patch that removes the cpumask_t type and uses cpuset_t type for characterizing a generic mask of CPUs: http://www.freebsd.org/~attilio/largeSMP/largeSMP-patchset-beta-0.diff This is part of a bigger effort which brought to serveral smaller commits along the way, in order to fix some edge cases. Things to pay attention at: - Userland and kerneland cpuset_t size can be different, thus when accessing to a kernel cpuset_t object from userland (via kvm_read() for example) a pattern similar to what pmccontrol does, in this patch, should be followed - There are some cpuset_t object in pcpu representing curcpu mask and !curcpu mask. With transition from cpumask_t to cpuset_t they become inefficient and not really useful. The next weeks I'll focus on removing them and make a smarter usage of the cpuset_t interface. Additively, please note that right now I clobbered pcpu accesses under scheduler pinnings, because it is possible more than a single atomic operation is needed for accessing a cpuset_t. When the cleanup happens those pinnings will go away. - I had to introduce, among the other things, functions for representing cpuset_t object in "visual" way, thus cpusetobj_strprint() and cpusetobj_strscan(). I got the desired format from what Linux already does, so that someone may be already used to it. Anyway strings will be represented as a serie of long, hexadecimal long words, all separated by ", ". The left-most represents the higher word, following natural bits representation. - I used cpusetobj_strscan() for implementing KTR_CPUMASK in a way it supports cpuset_t. Change the kernel config appropriately. - No MAXCPU has been bumped in the patch, but I encourage you to do so with your own kernel configurations. I really need to commit this patch before code slush happens, thus I plan to commit it on June 7th, if no one reports bugs or can make good point on his reviews. Please note that the patch has been greatly tested and reviewed on all FreeBSD tier-1 and tier-2 architectures. Anyway more testing and reviews are welcome to happen. Thanks, Attilio -- Peace can only be achieved by understanding - A. Einstein
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?BANLkTi=xgP64i2S=SE1zz-p07b7cTA06Zg>