-/*
+/**
+ * \file
* Copyright 2014 Xamarin Inc
+ * Licensed under the MIT license. See LICENSE file in the project root for full license information.
*/
#ifndef __MONO_SEQ_POINTS_H__
#define __MONO_SEQ_POINTS_H__
-#define MONO_SEQ_POINT_FLAG_NONEMPTY_STACK 1
-#define MONO_SEQ_POINT_FLAG_EXIT_IL 2
-
-/* IL offsets used to mark the sequence points belonging to method entry/exit events */
-#define METHOD_ENTRY_IL_OFFSET -1
-#define METHOD_EXIT_IL_OFFSET 0xffffff
-
-#define SEQ_POINT_AOT_EXT ".msym"
-
-/* Native offset used to mark seq points in dead code */
-#define SEQ_POINT_NATIVE_OFFSET_DEAD_CODE -1
-
-typedef struct {
- int il_offset, native_offset, flags;
- /* Offset of indexes of successor sequence points on the compressed buffer */
- int next_offset;
- /* Number of entries in next */
- int next_len;
-} SeqPoint;
-
-typedef struct MonoSeqPointInfo {
- int dummy[0];
-} MonoSeqPointInfo;
-
-typedef struct {
- SeqPoint seq_point;
- guint8* ptr;
- guint8* begin;
- guint8* end;
- gboolean has_debug_data;
-} SeqPointIterator;
-
-void
-seq_point_info_free (gpointer info);
+#include <mono/metadata/seq-points-data.h>
void
mono_save_seq_point_info (MonoCompile *cfg);
MonoSeqPointInfo*
-get_seq_points (MonoDomain *domain, MonoMethod *method);
-
-gboolean
-find_next_seq_point_for_native_offset (MonoDomain *domain, MonoMethod *method, gint32 native_offset, MonoSeqPointInfo **info, SeqPoint* seq_point);
+mono_get_seq_points (MonoDomain *domain, MonoMethod *method);
gboolean
-find_prev_seq_point_for_native_offset (MonoDomain *domain, MonoMethod *method, gint32 native_offset, MonoSeqPointInfo **info, SeqPoint* seq_point);
+mono_find_next_seq_point_for_native_offset (MonoDomain *domain, MonoMethod *method, gint32 native_offset, MonoSeqPointInfo **info, SeqPoint* seq_point);
gboolean
-find_seq_point (MonoDomain *domain, MonoMethod *method, gint32 il_offset, MonoSeqPointInfo **info, SeqPoint *seq_point);
+mono_find_prev_seq_point_for_native_offset (MonoDomain *domain, MonoMethod *method, gint32 native_offset, MonoSeqPointInfo **info, SeqPoint* seq_point);
gboolean
-seq_point_iterator_next (SeqPointIterator* it);
-
-void
-seq_point_iterator_init (SeqPointIterator* it, MonoSeqPointInfo* info);
+mono_find_seq_point (MonoDomain *domain, MonoMethod *method, gint32 il_offset, MonoSeqPointInfo **info, SeqPoint *seq_point);
void
-seq_point_init_next (MonoSeqPointInfo* info, SeqPoint sp, SeqPoint* next);
-
-int
-seq_point_info_write (MonoSeqPointInfo* info, guint8* buffer);
-
-int
-seq_point_info_read (MonoSeqPointInfo** info, guint8* buffer, gboolean copy);
-
-int
-seq_point_info_get_write_size (MonoSeqPointInfo* info);
-
-void
-bb_deduplicate_op_il_seq_points (MonoCompile *cfg, MonoBasicBlock *bb);
-
-void
-mono_image_get_aot_seq_point_path (MonoImage *image, char **str);
-
-/*
- * SeqPointData struct and functions
- * This is used to store/load/use sequence point from a file
- */
-
-typedef struct {
- guint32 token;
- MonoSeqPointInfo* seq_points;
- gboolean free_seq_points;
-} SeqPointDataEntry;
-
-typedef struct {
- SeqPointDataEntry* entries;
- int entry_count;
- int entry_capacity;
-} SeqPointData;
-
-void
-seq_point_data_init (SeqPointData *data, int entry_capacity);
-
-void
-seq_point_data_free (SeqPointData *data);
-
-gboolean
-seq_point_data_read (SeqPointData *data, char *path);
-
-gboolean
-seq_point_data_write (SeqPointData *data, char *path);
-
-void
-seq_point_data_add (SeqPointData *data, guint32 token, MonoSeqPointInfo* info);
-
-gboolean
-seq_point_data_get (SeqPointData *data, guint32 token, MonoSeqPointInfo** info);
+mono_bb_deduplicate_op_il_seq_points (MonoCompile *cfg, MonoBasicBlock *bb);
-#endif /* __MONO_SEQ_POINTS_H__ */
\ No newline at end of file
+#endif /* __MONO_SEQ_POINTS_H__ */