clear_tsk_thread_flag(task, TIF_SINGLESTEP);
 }
 
+void ppc_gethwdinfo(struct ppc_debug_info *dbginfo)
+{
+       dbginfo->version = 1;
+       dbginfo->num_instruction_bps = CONFIG_PPC_ADV_DEBUG_IACS;
+       dbginfo->num_data_bps = CONFIG_PPC_ADV_DEBUG_DACS;
+       dbginfo->num_condition_regs = CONFIG_PPC_ADV_DEBUG_DVCS;
+       dbginfo->data_bp_alignment = 4;
+       dbginfo->sizeof_condition = 4;
+       dbginfo->features = PPC_DEBUG_FEATURE_INSN_BP_RANGE |
+                           PPC_DEBUG_FEATURE_INSN_BP_MASK;
+       if (IS_ENABLED(CONFIG_PPC_ADV_DEBUG_DAC_RANGE))
+               dbginfo->features |= PPC_DEBUG_FEATURE_DATA_BP_RANGE |
+                                    PPC_DEBUG_FEATURE_DATA_BP_MASK;
+}
+
 int ptrace_get_debugreg(struct task_struct *child, unsigned long addr,
                        unsigned long __user *datalp)
 {
 
 extern const struct user_regset_view user_ppc_native_view;
 
 /* ptrace-(no)adv */
+void ppc_gethwdinfo(struct ppc_debug_info *dbginfo);
 int ptrace_get_debugreg(struct task_struct *child, unsigned long addr,
                        unsigned long __user *datalp);
 int ptrace_set_debugreg(struct task_struct *task, unsigned long addr, unsigned long data);
 
        clear_tsk_thread_flag(task, TIF_SINGLESTEP);
 }
 
+void ppc_gethwdinfo(struct ppc_debug_info *dbginfo)
+{
+       dbginfo->version = 1;
+       dbginfo->num_instruction_bps = 0;
+       if (ppc_breakpoint_available())
+               dbginfo->num_data_bps = 1;
+       else
+               dbginfo->num_data_bps = 0;
+       dbginfo->num_condition_regs = 0;
+       dbginfo->data_bp_alignment = sizeof(long);
+       dbginfo->sizeof_condition = 0;
+       if (IS_ENABLED(CONFIG_HAVE_HW_BREAKPOINT)) {
+               dbginfo->features = PPC_DEBUG_FEATURE_DATA_BP_RANGE;
+               if (dawr_enabled())
+                       dbginfo->features |= PPC_DEBUG_FEATURE_DATA_BP_DAWR;
+       } else {
+               dbginfo->features = 0;
+       }
+}
+
 int ptrace_get_debugreg(struct task_struct *child, unsigned long addr,
                        unsigned long __user *datalp)
 {
 
        case PPC_PTRACE_GETHWDBGINFO: {
                struct ppc_debug_info dbginfo;
 
-               dbginfo.version = 1;
-#ifdef CONFIG_PPC_ADV_DEBUG_REGS
-               dbginfo.num_instruction_bps = CONFIG_PPC_ADV_DEBUG_IACS;
-               dbginfo.num_data_bps = CONFIG_PPC_ADV_DEBUG_DACS;
-               dbginfo.num_condition_regs = CONFIG_PPC_ADV_DEBUG_DVCS;
-               dbginfo.data_bp_alignment = 4;
-               dbginfo.sizeof_condition = 4;
-               dbginfo.features = PPC_DEBUG_FEATURE_INSN_BP_RANGE |
-                                  PPC_DEBUG_FEATURE_INSN_BP_MASK;
-#ifdef CONFIG_PPC_ADV_DEBUG_DAC_RANGE
-               dbginfo.features |=
-                                  PPC_DEBUG_FEATURE_DATA_BP_RANGE |
-                                  PPC_DEBUG_FEATURE_DATA_BP_MASK;
-#endif
-#else /* !CONFIG_PPC_ADV_DEBUG_REGS */
-               dbginfo.num_instruction_bps = 0;
-               if (ppc_breakpoint_available())
-                       dbginfo.num_data_bps = 1;
-               else
-                       dbginfo.num_data_bps = 0;
-               dbginfo.num_condition_regs = 0;
-               dbginfo.data_bp_alignment = sizeof(long);
-               dbginfo.sizeof_condition = 0;
-#ifdef CONFIG_HAVE_HW_BREAKPOINT
-               dbginfo.features = PPC_DEBUG_FEATURE_DATA_BP_RANGE;
-               if (dawr_enabled())
-                       dbginfo.features |= PPC_DEBUG_FEATURE_DATA_BP_DAWR;
-#else
-               dbginfo.features = 0;
-#endif /* CONFIG_HAVE_HW_BREAKPOINT */
-#endif /* CONFIG_PPC_ADV_DEBUG_REGS */
+               ppc_gethwdinfo(&dbginfo);
 
                if (copy_to_user(datavp, &dbginfo,
                                 sizeof(struct ppc_debug_info)))