-#define likely(x) __builtin_expect(!!(x), 1)
-#define unlikely(x) __builtin_expect(!!(x), 0)
-
-#define weak_alias(name) __attribute__((weak, alias(name)))
-#define weak __attribute__((weak))
-#define noret __attribute__((noreturn))
-#define optimize(opt) __attribute__((optimize(opt)))
-#define must_inline __attribute__((always_inline))
-#define must_emit __attribute__((used))
-
-#define clz(bits) __builtin_clz(bits)
-#define sadd_overflow(a, b, of) __builtin_sadd_overflow(a, b, of)
-#define umul_overflow(a, b, of) __builtin_umul_overflow(a, b, of)
-#define offsetof(f, m) __builtin_offsetof(f, m)
-
-#define prefetch_rd(ptr, ll) __builtin_prefetch((ptr), 0, ll)
-#define prefetch_wr(ptr, ll) __builtin_prefetch((ptr), 1, ll)
+#define likely(x) __builtin_expect(!!(x), 1)
+#define unlikely(x) __builtin_expect(!!(x), 0)
+
+#define __section(name) __attribute__((section(name)))
+#define weak_alias(name) __attribute__((weak, alias(name)))
+#define optimize(opt) __attribute__((optimize(opt)))
+#define weak __attribute__((weak))
+#define noret __attribute__((noreturn))
+#define must_inline __attribute__((always_inline))
+#define must_emit __attribute__((used))
+#define unreachable __builtin_unreachable()
+#define no_inline __attribute__((noinline))
+
+#define _default weak
+
+#define msbiti (sizeof(int) * 8 - 1)
+#define clz(bits) __builtin_clz(bits)
+
+#ifdef CONFIG_ARCH_BITS_64
+#define msbitl (sizeof(long) * 8 - 1)
+#define clzl(bits) __builtin_clzl(bits)
+#else
+#define msbitl msbiti
+#define clzl(bits) clz(bits)
+#endif
+
+#define sadd_of(a, b, of) __builtin_sadd_overflow(a, b, of)
+#define saddl_of(a, b, of) __builtin_saddl_overflow(a, b, of)
+#define umul_of(a, b, of) __builtin_umul_overflow(a, b, of)
+#define umull_of(a, b, of) __builtin_umull_overflow(a, b, of)
+#define offsetof(f, m) __builtin_offsetof(f, m)
+
+#define prefetch_rd(ptr, ll) __builtin_prefetch((ptr), 0, ll)
+#define prefetch_wr(ptr, ll) __builtin_prefetch((ptr), 1, ll)