Richard Knutsson <[EMAIL PROTECTED]> writes: > Andreas Schwab wrote: >> Richard Knutsson <[EMAIL PROTECTED]> writes: >> >>> Andreas Schwab wrote: >>> >>>> Richard Knutsson <[EMAIL PROTECTED]> writes: >>>> >>>>> Vignesh Babu BM wrote: >>>>> >>>>>> @@ -175,7 +176,7 @@ static int __init hugetlb_setup_sz(char *str) >>>>>> tr_pages = 0x15557000UL; >>>>>> size = memparse(str, &str); >>>>>> - if (*str || (size & (size-1)) || !(tr_pages & size) || >>>>>> + if (*str || !is_power_of_2(size) || !(tr_pages & size) || >>>>>> size <= PAGE_SIZE || >>>>>> size >= (1UL << PAGE_SHIFT << MAX_ORDER)) { >>>>>> printk(KERN_WARNING "Invalid huge page size >>>>>> specified\n"); >>>>>> >>>>> As we talked about before; is this really correct? !is_power_of_2(0) == >>>>> true while (0 & (0-1)) == 0. >>>>> >>>> size == 0 is also covered by the next two conditions, so the overall value >>>> does not change. >>>> >>> Yes, but is it meant to state that 'size' is not a power of two? >>> >> >> What else can it mean? >> > What about !one_or_less_bit()?
Obviously not. Andreas. -- Andreas Schwab, SuSE Labs, [EMAIL PROTECTED] SuSE Linux Products GmbH, Maxfeldstraße 5, 90409 Nürnberg, Germany PGP key fingerprint = 58CA 54C7 6D53 942B 1756 01D3 44D5 214B 8276 4ED5 "And now for something completely different." - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/