/* Chrysalide - Outil d'analyse de fichiers binaires
 * break.h - prototypes pour la manipulation des points d'arrêt
 *
 * Copyright (C) 2010-2018 Cyrille Bagard
 *
 *  This file is part of Chrysalide.
 *
 *  Chrysalide is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 3 of the License, or
 *  (at your option) any later version.
 *
 *  Chrysalide is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with Chrysalide.  If not, see <http://www.gnu.org/licenses/>.
 */


#ifndef _DEBUG_BREAK_H
#define _DEBUG_BREAK_H


#include "misc.h"
#include "../arch/vmpa.h"



/* Origine des points d'arrêt en place */
typedef enum _RawBpOrigin
{
    RBO_INVALID  = (0 << 0),                /* Existance illégale          */
    RBO_USER     = (1 << 0),                /* Point d'arrêt utilisateur   */
    //RBO_COMPUTED = (1 << 1),                /* Arrêt sur un point spécial  */
    RBO_INTERNAL = (1 << 2),                /* Restauration transparente   */
    RBO_STEP     = (1 << 3),                /* Mise en place éphémère      */

    RBO_COUNT

} RawBpOrigin;


/* Définition d'un point d'arrêt appliqué */
typedef struct _raw_breakpoint raw_breakpoint;


/* Libère le coeur d'un point d'arrêt. */
void fini_raw_breakpoint(raw_breakpoint *);

/* Indique l'adresse du point d'arrêt dans la mémoire ciblée. */
virt_t get_raw_breakpoint_addr(const raw_breakpoint *);

/* Fournit l'adresse d'origine d'un point d'arrêt de pas à pas. */
virt_t get_raw_breakpoint_prev_addr(const raw_breakpoint *);

/* Effectue une comparaison entre adresse et point d'arrêt. */
int compare_raw_breakpoint_with_addr(const virt_t *, const raw_breakpoint **);

/* Effectue une comparaison entre deux points d'arrêt. */
int compare_raw_breakpoints(const raw_breakpoint **, const raw_breakpoint **);

/* Enregistre la source d'un point d'arrêt posé. */
void set_raw_breakpoint_origin(raw_breakpoint *, RawBpOrigin, dbg_thread_id_t, virt_t);

/* Oublie la source d'un point d'arrêt posé. */
void unset_raw_breakpoint_origin(raw_breakpoint *, RawBpOrigin, dbg_thread_id_t);

/* Indique si le point d'arrêt correspond à une source donnée. */
bool has_raw_breakpoint_origin(const raw_breakpoint *, RawBpOrigin, dbg_thread_id_t);

/* Indique si le point d'arrêt correspond à une origine donnée. */
bool has_raw_breakpoint_previous_address(const raw_breakpoint *, RawBpOrigin, dbg_thread_id_t, virt_t);

/* Indique si un point d'arrêt a encore une utilité. */
bool is_breakpoint_useless(const raw_breakpoint *);



#endif  /* _DEBUG_BREAK_H */