diff --git a/configure b/configure
index f43206849c718d3c1df995c390234de3d2af612b..da4036ec7b0c8400a3a7e2a57cb13679a9664eab 100755
--- a/configure
+++ b/configure
@@ -1077,6 +1077,7 @@ HAVE_LIST="
     alsa_asoundlib_h
     altivec_h
     arpa_inet_h
+    asm_mod_q
     asm_mod_y
     attribute_may_alias
     attribute_packed
@@ -2792,6 +2793,7 @@ EOF
     enabled neon    && check_asm neon    '"vadd.i16 q0, q0, q0"'
     enabled vfpv3   && check_asm vfpv3   '"vmov.f32 s0, #1.0"'
 
+    check_asm asm_mod_q '"add r0, %Q0, %R0" :: "r"((long long)0)'
     check_asm asm_mod_y '"vmul.i32 d0, d0, %y0" :: "x"(0)'
 
     enabled_all armv6t2 shared !pic && enable_pic
diff --git a/libavutil/arm/intmath.h b/libavutil/arm/intmath.h
index b6a45c1395f98bef793e0963619151f2b1dc37a1..fa31ecf6a57a1556dbf382d77589a4e85c1bfb79 100644
--- a/libavutil/arm/intmath.h
+++ b/libavutil/arm/intmath.h
@@ -97,6 +97,8 @@ static av_always_inline av_const int FASTDIV(int a, int b)
 
 #endif /* HAVE_ARMV6 */
 
+#if HAVE_ASM_MOD_Q
+
 #define av_clipl_int32 av_clipl_int32_arm
 static av_always_inline av_const int32_t av_clipl_int32_arm(int64_t a)
 {
@@ -110,6 +112,8 @@ static av_always_inline av_const int32_t av_clipl_int32_arm(int64_t a)
     return x;
 }
 
+#endif /* HAVE_ASM_MOD_Q */
+
 #endif /* HAVE_INLINE_ASM */
 
 #endif /* AVUTIL_ARM_INTMATH_H */
diff --git a/libavutil/arm/intreadwrite.h b/libavutil/arm/intreadwrite.h
index ed53330e39f352e222a4a89ddda074867d112928..6eff7332fbaa6c1f55f9451e06c0e8ba57cd88ec 100644
--- a/libavutil/arm/intreadwrite.h
+++ b/libavutil/arm/intreadwrite.h
@@ -61,6 +61,8 @@ static av_always_inline void AV_WN32(void *p, uint32_t v)
     __asm__ ("str  %1, %0" : "=m"(*(uint32_t *)p) : "r"(v));
 }
 
+#if HAVE_ASM_MOD_Q
+
 #define AV_RN64 AV_RN64
 static av_always_inline uint64_t AV_RN64(const void *p)
 {
@@ -82,6 +84,8 @@ static av_always_inline void AV_WN64(void *p, uint64_t v)
              : "r"(v));
 }
 
+#endif /* HAVE_ASM_MOD_Q */
+
 #endif /* HAVE_INLINE_ASM */
 
 #endif /* AVUTIL_ARM_INTREADWRITE_H */