1 /* -*- mode: C; c-basic-offset: 3; indent-tabs-mode: nil; -*- */
3 This file is part of drd, a thread error detector.
5 Copyright (C) 2006-2011 Bart Van Assche <bvanassche@acm.org>.
7 This program is free software; you can redistribute it and/or
8 modify it under the terms of the GNU General Public License as
9 published by the Free Software Foundation; either version 2 of the
10 License, or (at your option) any later version.
12 This program is distributed in the hope that it will be useful, but
13 WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
22 The GNU General Public License is contained in the file COPYING.
26 #ifndef __DRD_THREAD_BITMAP_H
27 #define __DRD_THREAD_BITMAP_H
30 #include "drd_bitmap.h"
31 #include "drd_thread.h" /* running_thread_get_segment() */
32 #include "pub_drd_bitmap.h"
36 Bool bm_access_load_1_triggers_conflict(const Addr a1)
38 DRD_(bm_access_load_1)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1);
39 return DRD_(bm_load_1_has_conflict_with)(DRD_(thread_get_conflict_set)(),
44 Bool bm_access_load_2_triggers_conflict(const Addr a1)
48 bm_access_aligned_load(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1, 2);
49 return bm_aligned_load_has_conflict_with(DRD_(thread_get_conflict_set)(),
54 DRD_(bm_access_range)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()),
56 return DRD_(bm_has_conflict_with)(DRD_(thread_get_conflict_set)(),
62 Bool bm_access_load_4_triggers_conflict(const Addr a1)
66 bm_access_aligned_load(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1, 4);
67 return bm_aligned_load_has_conflict_with(DRD_(thread_get_conflict_set)(),
72 DRD_(bm_access_range)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()),
74 return DRD_(bm_has_conflict_with)(DRD_(thread_get_conflict_set)(),
80 Bool bm_access_load_8_triggers_conflict(const Addr a1)
84 bm_access_aligned_load(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1, 8);
85 return bm_aligned_load_has_conflict_with(DRD_(thread_get_conflict_set)(),
88 else if ((a1 & 3) == 0)
90 bm_access_aligned_load(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1 + 0, 4);
91 bm_access_aligned_load(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1 + 4, 4);
92 return DRD_(bm_has_conflict_with)(DRD_(thread_get_conflict_set)(),
97 DRD_(bm_access_range)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()),
99 return DRD_(bm_has_conflict_with)(DRD_(thread_get_conflict_set)(),
105 Bool bm_access_load_triggers_conflict(const Addr a1, const Addr a2)
107 DRD_(bm_access_range_load)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1, a2);
108 return DRD_(bm_load_has_conflict_with)(DRD_(thread_get_conflict_set)(),
113 Bool bm_access_store_1_triggers_conflict(const Addr a1)
115 DRD_(bm_access_store_1)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1);
116 return DRD_(bm_store_1_has_conflict_with)(DRD_(thread_get_conflict_set)(),
121 Bool bm_access_store_2_triggers_conflict(const Addr a1)
125 bm_access_aligned_store(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1, 2);
126 return bm_aligned_store_has_conflict_with(DRD_(thread_get_conflict_set)(),
131 DRD_(bm_access_range)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()),
133 return DRD_(bm_has_conflict_with)(DRD_(thread_get_conflict_set)(),
139 Bool bm_access_store_4_triggers_conflict(const Addr a1)
143 bm_access_aligned_store(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1, 4);
144 return bm_aligned_store_has_conflict_with(DRD_(thread_get_conflict_set)(),
149 DRD_(bm_access_range)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()),
151 return DRD_(bm_has_conflict_with)(DRD_(thread_get_conflict_set)(),
157 Bool bm_access_store_8_triggers_conflict(const Addr a1)
161 bm_access_aligned_store(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1, 8);
162 return bm_aligned_store_has_conflict_with(DRD_(thread_get_conflict_set)(),
165 else if ((a1 & 3) == 0)
167 bm_access_aligned_store(DRD_(sg_bm)(DRD_(running_thread_get_segment)()),
169 bm_access_aligned_store(DRD_(sg_bm)(DRD_(running_thread_get_segment)()),
171 return DRD_(bm_has_conflict_with)(DRD_(thread_get_conflict_set)(),
176 DRD_(bm_access_range)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()),
178 return DRD_(bm_has_conflict_with)(DRD_(thread_get_conflict_set)(),
184 Bool bm_access_store_triggers_conflict(const Addr a1, const Addr a2)
186 DRD_(bm_access_range_store)(DRD_(sg_bm)(DRD_(running_thread_get_segment)()), a1, a2);
187 return DRD_(bm_store_has_conflict_with)(DRD_(thread_get_conflict_set)(),
191 #endif // __DRD_THREAD_BITMAP_H