blob: c8e582a716da75a573f45fab87de7208cb27d7de [file] [log] [blame]
bartbedfd232009-03-26 19:07:15 +00001/* -*- mode: C; c-basic-offset: 3; -*- */
sewardjaf44c822007-11-25 14:01:38 +00002/*
bart86562bd2009-02-16 19:43:56 +00003 This file is part of drd, a thread error detector.
sewardjaf44c822007-11-25 14:01:38 +00004
bart86562bd2009-02-16 19:43:56 +00005 Copyright (C) 2006-2009 Bart Van Assche <bart.vanassche@gmail.com>.
sewardjaf44c822007-11-25 14:01:38 +00006
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.
11
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.
16
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
20 02111-1307, USA.
21
22 The GNU General Public License is contained in the file COPYING.
23*/
24
25
26#ifndef __DRD_ERROR_H
27#define __DRD_ERROR_H
28
29
bartb515eb12008-03-07 18:52:38 +000030#include "pub_drd_bitmap.h" // BmAccessTypeT
sewardjaf44c822007-11-25 14:01:38 +000031#include "drd_thread.h" // DrdThreadId
32#include "pub_tool_basics.h" // SizeT
33#include "pub_tool_debuginfo.h" // SegInfo
34#include "pub_tool_errormgr.h" // ExeContext
35
36
37/* DRD error types. */
38
39typedef enum {
bart5fc70e62008-03-23 07:54:02 +000040#define STR_DataRaceErr "ConflictingAccess"
sewardjaf44c822007-11-25 14:01:38 +000041 DataRaceErr = 1,
bart5fc70e62008-03-23 07:54:02 +000042#define STR_MutexErr "MutexErr"
sewardjaf44c822007-11-25 14:01:38 +000043 MutexErr = 2,
bart5fc70e62008-03-23 07:54:02 +000044#define STR_CondErr "CondErr"
bart3b1ee452008-02-29 19:28:15 +000045 CondErr = 3,
bart5fc70e62008-03-23 07:54:02 +000046#define STR_CondDestrErr "CondDestrErr"
bart3bb1cec2008-06-28 16:01:43 +000047 CondDestrErr = 4,
48#define STR_CondRaceErr "CondRaceErr"
49 CondRaceErr = 5,
50#define STR_CondWaitErr "CondWaitErr"
51 CondWaitErr = 6,
bart5fc70e62008-03-23 07:54:02 +000052#define STR_SemaphoreErr "SemaphoreErr"
bart3bb1cec2008-06-28 16:01:43 +000053 SemaphoreErr = 7,
bart5fc70e62008-03-23 07:54:02 +000054#define STR_BarrierErr "BarrierErr"
bart3bb1cec2008-06-28 16:01:43 +000055 BarrierErr = 8,
bart5fc70e62008-03-23 07:54:02 +000056#define STR_RwlockErr "RwlockErr"
bart3bb1cec2008-06-28 16:01:43 +000057 RwlockErr = 9,
bart9d5b7962008-05-14 12:25:00 +000058#define STR_HoldtimeErr "HoldtimeErr"
bart3bb1cec2008-06-28 16:01:43 +000059 HoldtimeErr = 10,
bart5fc70e62008-03-23 07:54:02 +000060#define STR_GenericErr "GenericErr"
bart3bb1cec2008-06-28 16:01:43 +000061 GenericErr = 11,
bartb48bde22009-07-31 08:26:17 +000062#define STR_InvalidThreadId "InvalidThreadId"
63 InvalidThreadId = 12,
bart66f196d2009-08-15 10:50:35 +000064#define STR_UnimpClReq "UnimpClReq"
65 UnimpClReq = 13,
sewardjaf44c822007-11-25 14:01:38 +000066} DrdErrorKind;
67
68/* The classification of a faulting address. */
bart31b983d2010-02-21 14:52:59 +000069typedef
70enum {
sewardjaf44c822007-11-25 14:01:38 +000071 //Undescribed, // as-yet unclassified
bart31b983d2010-02-21 14:52:59 +000072 eStack,
sewardjaf44c822007-11-25 14:01:38 +000073 eUnknown, // classification yielded nothing useful
74 //Freed,
bart31b983d2010-02-21 14:52:59 +000075 eMallocd,
sewardjaf44c822007-11-25 14:01:38 +000076 eSegment, // in a segment (as defined in pub_tool_debuginfo.h)
77 //UserG, // in a user-defined block
78 //Mempool, // in a mempool
79 //Register, // in a register; for Param errors only
80}
81 AddrKind;
82
83/* Records info about a faulting address. */
84typedef
85struct { // Used by:
86 AddrKind akind; // ALL
87 SizeT size; // ALL
njnc4431bf2009-01-15 21:29:24 +000088 PtrdiffT rwoffset; // ALL
sewardjaf44c822007-11-25 14:01:38 +000089 ExeContext* lastchange; // Mallocd
90 DrdThreadId stack_tid; // Stack
sewardjb8b79ad2008-03-03 01:35:41 +000091 DebugInfo* debuginfo; // Segment
sewardjaf44c822007-11-25 14:01:38 +000092 Char name[256]; // Segment
93 Char descr[256]; // Segment
bartd45d9952009-05-31 18:53:54 +000094} AddrInfo;
sewardjaf44c822007-11-25 14:01:38 +000095
bartd45d9952009-05-31 18:53:54 +000096/*
97 * NOTE: the first member of each error info structure MUST be the thread ID
98 * in which the error has been observed.
99 */
sewardjaf44c822007-11-25 14:01:38 +0000100typedef struct {
bart354009c2008-03-16 10:42:33 +0000101 DrdThreadId tid; // Thread ID of the running thread.
sewardjaf44c822007-11-25 14:01:38 +0000102 Addr addr; // Conflicting address in current thread.
103 SizeT size; // Size in bytes of conflicting operation.
104 BmAccessTypeT access_type; // Access type: load or store.
105} DataRaceErrInfo;
106
107typedef struct {
bartd45d9952009-05-31 18:53:54 +0000108 DrdThreadId tid;
109 Addr mutex;
110 Int recursion_count;
sewardjaf44c822007-11-25 14:01:38 +0000111 DrdThreadId owner;
112} MutexErrInfo;
113
114typedef struct {
bartd45d9952009-05-31 18:53:54 +0000115 DrdThreadId tid;
116 Addr cond;
bart3b1ee452008-02-29 19:28:15 +0000117} CondErrInfo;
118
119typedef struct {
bartd45d9952009-05-31 18:53:54 +0000120 DrdThreadId tid;
bart3bb1cec2008-06-28 16:01:43 +0000121 Addr cond;
122 Addr mutex;
bartd45d9952009-05-31 18:53:54 +0000123 DrdThreadId owner;
bart3bb1cec2008-06-28 16:01:43 +0000124} CondDestrErrInfo;
125
126typedef struct {
bartd45d9952009-05-31 18:53:54 +0000127 DrdThreadId tid;
128 Addr cond;
129 Addr mutex;
sewardjaf44c822007-11-25 14:01:38 +0000130} CondRaceErrInfo;
131
132typedef struct {
bartd45d9952009-05-31 18:53:54 +0000133 DrdThreadId tid;
134 Addr cond;
135 Addr mutex1;
136 Addr mutex2;
bart3bb1cec2008-06-28 16:01:43 +0000137} CondWaitErrInfo;
bart3b1ee452008-02-29 19:28:15 +0000138
139typedef struct {
bartd45d9952009-05-31 18:53:54 +0000140 DrdThreadId tid;
141 Addr semaphore;
bart3b1ee452008-02-29 19:28:15 +0000142} SemaphoreErrInfo;
143
144typedef struct {
bartd45d9952009-05-31 18:53:54 +0000145 DrdThreadId tid;
bartd2c5eae2009-02-21 15:27:04 +0000146 Addr barrier;
147 DrdThreadId other_tid;
148 ExeContext* other_context;
bart3b1ee452008-02-29 19:28:15 +0000149} BarrierErrInfo;
sewardjaf44c822007-11-25 14:01:38 +0000150
barte883bc82008-02-26 19:13:04 +0000151typedef struct {
bartd45d9952009-05-31 18:53:54 +0000152 DrdThreadId tid;
153 Addr rwlock;
bart777f7fe2008-03-02 17:43:18 +0000154} RwlockErrInfo;
155
156typedef struct {
bartd45d9952009-05-31 18:53:54 +0000157 DrdThreadId tid;
bartbedfd232009-03-26 19:07:15 +0000158 Addr synchronization_object;
159 ExeContext* acquired_at;
160 UInt hold_time_ms;
161 UInt threshold_ms;
bart9d5b7962008-05-14 12:25:00 +0000162} HoldtimeErrInfo;
163
164typedef struct {
bartd45d9952009-05-31 18:53:54 +0000165 DrdThreadId tid;
barte883bc82008-02-26 19:13:04 +0000166} GenericErrInfo;
167
bartb48bde22009-07-31 08:26:17 +0000168typedef struct {
169 DrdThreadId tid;
170 ULong ptid;
171} InvalidThreadIdInfo;
bart16d76e52008-03-18 17:08:08 +0000172
bart66f196d2009-08-15 10:50:35 +0000173typedef struct {
174 DrdThreadId tid;
175 Char* descr;
176} UnimpClReqInfo;
177
bart246fbf22009-02-15 14:46:17 +0000178void DRD_(set_show_conflicting_segments)(const Bool scs);
bart1335ecc2009-02-14 16:10:53 +0000179void DRD_(register_error_handlers)(void);
sewardjaf44c822007-11-25 14:01:38 +0000180
181
182#endif /* __DRD_ERROR_H */