#define __is_signed_type(type) (((type)(-1)) < (type)1)
 
-#define __bpf_cmp(LHS, OP, SIGN, PRED, RHS, DEFAULT)                                           \
+#define __bpf_cmp(LHS, OP, PRED, RHS, DEFAULT)                                         \
        ({                                                                                      \
                __label__ l_true;                                                               \
                bool ret = DEFAULT;                                                             \
-               asm volatile goto("if %[lhs] " SIGN #OP " %[rhs] goto %l[l_true]"               \
+               asm volatile goto("if %[lhs] " OP " %[rhs] goto %l[l_true]"             \
                                  :: [lhs] "r"((short)LHS), [rhs] PRED (RHS) :: l_true);        \
                ret = !DEFAULT;                                                                 \
 l_true:                                                                                                \
  * __lhs OP __rhs below will catch the mistake.
  * Be aware that we check only __lhs to figure out the sign of compare.
  */
-#define _bpf_cmp(LHS, OP, RHS, NOFLIP)                                                         \
+#define _bpf_cmp(LHS, OP, RHS, UNLIKELY)                                                               \
        ({                                                                                      \
                typeof(LHS) __lhs = (LHS);                                                      \
                typeof(RHS) __rhs = (RHS);                                                      \
                (void)(__lhs OP __rhs);                                                         \
                if (__cmp_cannot_be_signed(OP) || !__is_signed_type(typeof(__lhs))) {           \
                        if (sizeof(__rhs) == 8)                                                 \
-                               ret = __bpf_cmp(__lhs, OP, "", "r", __rhs, NOFLIP);             \
+                               /* "i" will truncate 64-bit constant into s32,                  \
+                                * so we have to use extra register via "r".                    \
+                                */                                                             \
+                               ret = __bpf_cmp(__lhs, #OP, "r", __rhs, UNLIKELY);              \
                        else                                                                    \
-                               ret = __bpf_cmp(__lhs, OP, "", "i", __rhs, NOFLIP);             \
+                               ret = __bpf_cmp(__lhs, #OP, "ri", __rhs, UNLIKELY);             \
                } else {                                                                        \
                        if (sizeof(__rhs) == 8)                                                 \
-                               ret = __bpf_cmp(__lhs, OP, "s", "r", __rhs, NOFLIP);            \
+                               ret = __bpf_cmp(__lhs, "s"#OP, "r", __rhs, UNLIKELY);           \
                        else                                                                    \
-                               ret = __bpf_cmp(__lhs, OP, "s", "i", __rhs, NOFLIP);            \
+                               ret = __bpf_cmp(__lhs, "s"#OP, "ri", __rhs, UNLIKELY);          \
                }                                                                               \
                ret;                                                                            \
        })
 #ifndef bpf_cmp_likely
 #define bpf_cmp_likely(LHS, OP, RHS)                                                           \
        ({                                                                                      \
-               bool ret;                                                                       \
+               bool ret = 0;                                                                   \
                if (__builtin_strcmp(#OP, "==") == 0)                                           \
                        ret = _bpf_cmp(LHS, !=, RHS, false);                                    \
                else if (__builtin_strcmp(#OP, "!=") == 0)                                      \
                else if (__builtin_strcmp(#OP, ">=") == 0)                                      \
                        ret = _bpf_cmp(LHS, <, RHS, false);                                     \
                else                                                                            \
-                       (void) "bug";                                                           \
+                       asm volatile("r0 " #OP " invalid compare");                             \
                ret;                                                                            \
        })
 #endif