On 05/28/2013 05:53 AM, Kirill A. Shutemov wrote: > Dave Hansen wrote: >> On 05/11/2013 06:23 PM, Kirill A. Shutemov wrote: >>> + VM_BUG_ON(PageTransHuge(old)); >>> + VM_BUG_ON(PageTransHuge(new)); >>> VM_BUG_ON(!PageLocked(old)); >>> VM_BUG_ON(!PageLocked(new)); >>> VM_BUG_ON(new->mapping); >> >> The code calling replace_page_cache_page() has a bunch of fallback and >> error returning code. It seems a little bit silly to bring the whole >> machine down when you could just WARN_ONCE() and return an error code >> like fuse already does: > > What about: > > if (WARN_ONCE(PageTransHuge(old) || PageTransHuge(new), > "%s: unexpected huge page\n", __func__)) > return -EINVAL; That looks sane to me. But, please do make sure to differentiate in the error message between thp and hugetlbfs (if you have the room). BTW, I'm also not sure you need to print the function name. The WARN_ON() register dump usually has the function name. -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>