00001 // Copyright (C) 2001, Compaq Computer Corporation 00002 00003 // This file is part of Vesta. 00004 00005 // Vesta is free software; you can redistribute it and/or 00006 // modify it under the terms of the GNU Lesser General Public 00007 // License as published by the Free Software Foundation; either 00008 // version 2.1 of the License, or (at your option) any later version. 00009 00010 // Vesta is distributed in the hope that it will be useful, 00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00013 // Lesser General Public License for more details. 00014 00015 // You should have received a copy of the GNU Lesser General Public 00016 // License along with Vesta; if not, write to the Free Software 00017 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00018 00019 // Last modified on Wed Nov 7 14:40:45 EST 2001 by ken@xorian.net 00020 // modified on Mon May 3 16:04:42 PDT 1999 by heydon 00021 00022 #include <Basics.H> 00023 #include "TableUtils.H" 00024 00025 const Bit32 One32U = 1U; 00026 00027 Bit16 Log_2(Bit32 x) throw () 00028 /* Return "ceiling(log_2(x))". */ 00029 { 00030 assert(x > 0U); 00031 Bit16 log = 0; 00032 for (Bit32 n = One32U; n < x; n <<= 1) log++; 00033 return log; 00034 }