diff mbox series

[1/6] exec: Move user-only watchpoint stubs inline

Message ID 20190824213451.31118-2-richard.henderson@linaro.org
State Superseded
Headers show
Series exec: Cleanup watchpoints | expand

Commit Message

Richard Henderson Aug. 24, 2019, 9:34 p.m. UTC
Let the user-only watchpoint stubs resolve to empty inline functions.

Signed-off-by: Richard Henderson <richard.henderson@linaro.org>

---
 include/hw/core/cpu.h | 23 +++++++++++++++++++++++
 exec.c                | 26 ++------------------------
 2 files changed, 25 insertions(+), 24 deletions(-)

-- 
2.17.1

Comments

David Hildenbrand Aug. 26, 2019, 7:45 a.m. UTC | #1
On 24.08.19 23:34, Richard Henderson wrote:
> Let the user-only watchpoint stubs resolve to empty inline functions.

> 

> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>

> ---

>  include/hw/core/cpu.h | 23 +++++++++++++++++++++++

>  exec.c                | 26 ++------------------------

>  2 files changed, 25 insertions(+), 24 deletions(-)

> 

> diff --git a/include/hw/core/cpu.h b/include/hw/core/cpu.h

> index 77fca95a40..6de688059d 100644

> --- a/include/hw/core/cpu.h

> +++ b/include/hw/core/cpu.h

> @@ -1070,12 +1070,35 @@ static inline bool cpu_breakpoint_test(CPUState *cpu, vaddr pc, int mask)

>      return false;

>  }

>  

> +#ifdef CONFIG_USER_ONLY

> +static inline int cpu_watchpoint_insert(CPUState *cpu, vaddr addr, vaddr len,

> +                                        int flags, CPUWatchpoint **watchpoint)

> +{

> +    return -ENOSYS;

> +}

> +

> +static inline int cpu_watchpoint_remove(CPUState *cpu, vaddr addr,

> +                                        vaddr len, int flags)

> +{

> +    return -ENOSYS;

> +}

> +

> +static inline void cpu_watchpoint_remove_by_ref(CPUState *cpu,

> +                                                CPUWatchpoint *wp)

> +{

> +}

> +

> +static inline void cpu_watchpoint_remove_all(CPUState *cpu, int mask)

> +{

> +}

> +#else

>  int cpu_watchpoint_insert(CPUState *cpu, vaddr addr, vaddr len,

>                            int flags, CPUWatchpoint **watchpoint);

>  int cpu_watchpoint_remove(CPUState *cpu, vaddr addr,

>                            vaddr len, int flags);

>  void cpu_watchpoint_remove_by_ref(CPUState *cpu, CPUWatchpoint *watchpoint);

>  void cpu_watchpoint_remove_all(CPUState *cpu, int mask);

> +#endif

>  

>  /**

>   * cpu_get_address_space:

> diff --git a/exec.c b/exec.c

> index 53a15b7ad7..31fb75901f 100644

> --- a/exec.c

> +++ b/exec.c

> @@ -1062,28 +1062,7 @@ static void breakpoint_invalidate(CPUState *cpu, target_ulong pc)

>  }

>  #endif

>  

> -#if defined(CONFIG_USER_ONLY)

> -void cpu_watchpoint_remove_all(CPUState *cpu, int mask)

> -

> -{

> -}

> -

> -int cpu_watchpoint_remove(CPUState *cpu, vaddr addr, vaddr len,

> -                          int flags)

> -{

> -    return -ENOSYS;

> -}

> -

> -void cpu_watchpoint_remove_by_ref(CPUState *cpu, CPUWatchpoint *watchpoint)

> -{

> -}

> -

> -int cpu_watchpoint_insert(CPUState *cpu, vaddr addr, vaddr len,

> -                          int flags, CPUWatchpoint **watchpoint)

> -{

> -    return -ENOSYS;

> -}

> -#else

> +#ifndef CONFIG_USER_ONLY

>  /* Add a watchpoint.  */

>  int cpu_watchpoint_insert(CPUState *cpu, vaddr addr, vaddr len,

>                            int flags, CPUWatchpoint **watchpoint)

> @@ -1173,8 +1152,7 @@ static inline bool cpu_watchpoint_address_matches(CPUWatchpoint *wp,

>  

>      return !(addr > wpend || wp->vaddr > addrend);

>  }

> -

> -#endif

> +#endif /* !CONFIG_USER_ONLY */

>  

>  /* Add a breakpoint.  */

>  int cpu_breakpoint_insert(CPUState *cpu, vaddr pc, int flags,

> 


Reviewed-by: David Hildenbrand <david@redhat.com>


-- 

Thanks,

David / dhildenb
diff mbox series

Patch

diff --git a/include/hw/core/cpu.h b/include/hw/core/cpu.h
index 77fca95a40..6de688059d 100644
--- a/include/hw/core/cpu.h
+++ b/include/hw/core/cpu.h
@@ -1070,12 +1070,35 @@  static inline bool cpu_breakpoint_test(CPUState *cpu, vaddr pc, int mask)
     return false;
 }
 
+#ifdef CONFIG_USER_ONLY
+static inline int cpu_watchpoint_insert(CPUState *cpu, vaddr addr, vaddr len,
+                                        int flags, CPUWatchpoint **watchpoint)
+{
+    return -ENOSYS;
+}
+
+static inline int cpu_watchpoint_remove(CPUState *cpu, vaddr addr,
+                                        vaddr len, int flags)
+{
+    return -ENOSYS;
+}
+
+static inline void cpu_watchpoint_remove_by_ref(CPUState *cpu,
+                                                CPUWatchpoint *wp)
+{
+}
+
+static inline void cpu_watchpoint_remove_all(CPUState *cpu, int mask)
+{
+}
+#else
 int cpu_watchpoint_insert(CPUState *cpu, vaddr addr, vaddr len,
                           int flags, CPUWatchpoint **watchpoint);
 int cpu_watchpoint_remove(CPUState *cpu, vaddr addr,
                           vaddr len, int flags);
 void cpu_watchpoint_remove_by_ref(CPUState *cpu, CPUWatchpoint *watchpoint);
 void cpu_watchpoint_remove_all(CPUState *cpu, int mask);
+#endif
 
 /**
  * cpu_get_address_space:
diff --git a/exec.c b/exec.c
index 53a15b7ad7..31fb75901f 100644
--- a/exec.c
+++ b/exec.c
@@ -1062,28 +1062,7 @@  static void breakpoint_invalidate(CPUState *cpu, target_ulong pc)
 }
 #endif
 
-#if defined(CONFIG_USER_ONLY)
-void cpu_watchpoint_remove_all(CPUState *cpu, int mask)
-
-{
-}
-
-int cpu_watchpoint_remove(CPUState *cpu, vaddr addr, vaddr len,
-                          int flags)
-{
-    return -ENOSYS;
-}
-
-void cpu_watchpoint_remove_by_ref(CPUState *cpu, CPUWatchpoint *watchpoint)
-{
-}
-
-int cpu_watchpoint_insert(CPUState *cpu, vaddr addr, vaddr len,
-                          int flags, CPUWatchpoint **watchpoint)
-{
-    return -ENOSYS;
-}
-#else
+#ifndef CONFIG_USER_ONLY
 /* Add a watchpoint.  */
 int cpu_watchpoint_insert(CPUState *cpu, vaddr addr, vaddr len,
                           int flags, CPUWatchpoint **watchpoint)
@@ -1173,8 +1152,7 @@  static inline bool cpu_watchpoint_address_matches(CPUWatchpoint *wp,
 
     return !(addr > wpend || wp->vaddr > addrend);
 }
-
-#endif
+#endif /* !CONFIG_USER_ONLY */
 
 /* Add a breakpoint.  */
 int cpu_breakpoint_insert(CPUState *cpu, vaddr pc, int flags,