njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 1 | |
| 2 | /*--------------------------------------------------------------------*/ |
njn | c953984 | 2002-10-02 13:26:35 +0000 | [diff] [blame] | 3 | /*--- Management of memory error messages. ---*/ |
njn25 | cac76cb | 2002-09-23 11:21:57 +0000 | [diff] [blame] | 4 | /*--- mc_errcontext.c ---*/ |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 5 | /*--------------------------------------------------------------------*/ |
| 6 | |
| 7 | /* |
nethercote | 137bc55 | 2003-11-14 17:47:54 +0000 | [diff] [blame] | 8 | This file is part of MemCheck, a heavyweight Valgrind tool for |
njn | c953984 | 2002-10-02 13:26:35 +0000 | [diff] [blame] | 9 | detecting memory errors. |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 10 | |
njn | 0e1b514 | 2003-04-15 14:58:06 +0000 | [diff] [blame] | 11 | Copyright (C) 2000-2003 Julian Seward |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 12 | jseward@acm.org |
| 13 | |
| 14 | This program is free software; you can redistribute it and/or |
| 15 | modify it under the terms of the GNU General Public License as |
| 16 | published by the Free Software Foundation; either version 2 of the |
| 17 | License, or (at your option) any later version. |
| 18 | |
| 19 | This program is distributed in the hope that it will be useful, but |
| 20 | WITHOUT ANY WARRANTY; without even the implied warranty of |
| 21 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| 22 | General Public License for more details. |
| 23 | |
| 24 | You should have received a copy of the GNU General Public License |
| 25 | along with this program; if not, write to the Free Software |
| 26 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA |
| 27 | 02111-1307, USA. |
| 28 | |
| 29 | The GNU General Public License is contained in the file COPYING. |
| 30 | */ |
| 31 | |
njn25 | cac76cb | 2002-09-23 11:21:57 +0000 | [diff] [blame] | 32 | #include "mc_include.h" |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 33 | |
| 34 | /*------------------------------------------------------------*/ |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 35 | /*--- Printing errors ---*/ |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 36 | /*------------------------------------------------------------*/ |
| 37 | |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 38 | void SK_(pp_SkinError) ( Error* err ) |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 39 | { |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 40 | MAC_Error* err_extra = VG_(get_error_extra)(err); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 41 | |
njn | 810086f | 2002-11-14 12:42:47 +0000 | [diff] [blame] | 42 | switch (VG_(get_error_kind)(err)) { |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 43 | case CoreMemErr: |
| 44 | if (err_extra->isWrite) { |
| 45 | VG_(message)(Vg_UserMsg, |
njn | 810086f | 2002-11-14 12:42:47 +0000 | [diff] [blame] | 46 | "%s contains unaddressable byte(s)", VG_(get_error_string)(err)); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 47 | } else { |
| 48 | VG_(message)(Vg_UserMsg, |
| 49 | "%s contains uninitialised or unaddressable byte(s)", |
njn | 810086f | 2002-11-14 12:42:47 +0000 | [diff] [blame] | 50 | VG_(get_error_string)(err)); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 51 | } |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 52 | VG_(pp_ExeContext)( VG_(get_error_where)(err) ); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 53 | break; |
| 54 | |
| 55 | case ValueErr: |
| 56 | if (err_extra->size == 0) { |
| 57 | VG_(message)( |
| 58 | Vg_UserMsg, |
| 59 | "Conditional jump or move depends on uninitialised value(s)"); |
| 60 | } else { |
| 61 | VG_(message)(Vg_UserMsg, |
| 62 | "Use of uninitialised value of size %d", |
| 63 | err_extra->size); |
| 64 | } |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 65 | VG_(pp_ExeContext)( VG_(get_error_where)(err) ); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 66 | break; |
| 67 | |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 68 | case ParamErr: |
| 69 | if (err_extra->isWrite) { |
| 70 | VG_(message)(Vg_UserMsg, |
| 71 | "Syscall param %s contains unaddressable byte(s)", |
njn | 810086f | 2002-11-14 12:42:47 +0000 | [diff] [blame] | 72 | VG_(get_error_string)(err)); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 73 | } else { |
| 74 | VG_(message)(Vg_UserMsg, |
| 75 | "Syscall param %s contains uninitialised or " |
| 76 | "unaddressable byte(s)", |
njn | 810086f | 2002-11-14 12:42:47 +0000 | [diff] [blame] | 77 | VG_(get_error_string)(err)); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 78 | } |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 79 | VG_(pp_ExeContext)( VG_(get_error_where)(err) ); |
| 80 | MAC_(pp_AddrInfo)(VG_(get_error_address)(err), &err_extra->addrinfo); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 81 | break; |
| 82 | |
| 83 | case UserErr: |
| 84 | if (err_extra->isWrite) { |
| 85 | VG_(message)(Vg_UserMsg, |
| 86 | "Unaddressable byte(s) found during client check request"); |
| 87 | } else { |
| 88 | VG_(message)(Vg_UserMsg, |
| 89 | "Uninitialised or " |
| 90 | "unaddressable byte(s) found during client check request"); |
| 91 | } |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 92 | VG_(pp_ExeContext)( VG_(get_error_where)(err) ); |
| 93 | MAC_(pp_AddrInfo)(VG_(get_error_address)(err), &err_extra->addrinfo); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 94 | break; |
| 95 | |
| 96 | default: |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 97 | MAC_(pp_shared_SkinError)(err); |
| 98 | break; |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 99 | } |
| 100 | } |
| 101 | |
| 102 | /*------------------------------------------------------------*/ |
| 103 | /*--- Recording errors ---*/ |
| 104 | /*------------------------------------------------------------*/ |
| 105 | |
njn | 810086f | 2002-11-14 12:42:47 +0000 | [diff] [blame] | 106 | /* Creates a copy of the `extra' part, updates the copy with address info if |
| 107 | necessary, and returns the copy. */ |
sewardj | af48a60 | 2003-07-06 00:54:47 +0000 | [diff] [blame] | 108 | /* This one called from generated code and non-generated code. */ |
njn | 7271864 | 2003-07-24 08:45:32 +0000 | [diff] [blame] | 109 | void MC_(record_value_error) ( ThreadId tid, Int size ) |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 110 | { |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 111 | MAC_Error err_extra; |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 112 | |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 113 | MAC_(clear_MAC_Error)( &err_extra ); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 114 | err_extra.size = size; |
njn | 7271864 | 2003-07-24 08:45:32 +0000 | [diff] [blame] | 115 | VG_(maybe_record_error)( tid, ValueErr, /*addr*/0, /*s*/NULL, &err_extra ); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 116 | } |
| 117 | |
njn | 66fe05a | 2003-07-22 09:12:33 +0000 | [diff] [blame] | 118 | /* This called from non-generated code */ |
njn | 34419c1 | 2003-05-02 17:24:29 +0000 | [diff] [blame] | 119 | |
njn | 7271864 | 2003-07-24 08:45:32 +0000 | [diff] [blame] | 120 | void MC_(record_user_error) ( ThreadId tid, Addr a, Bool isWrite ) |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 121 | { |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 122 | MAC_Error err_extra; |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 123 | |
njn | 7271864 | 2003-07-24 08:45:32 +0000 | [diff] [blame] | 124 | sk_assert(VG_INVALID_THREADID != tid); |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 125 | MAC_(clear_MAC_Error)( &err_extra ); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 126 | err_extra.addrinfo.akind = Undescribed; |
| 127 | err_extra.isWrite = isWrite; |
njn | 7271864 | 2003-07-24 08:45:32 +0000 | [diff] [blame] | 128 | VG_(maybe_record_error)( tid, UserErr, a, /*s*/NULL, &err_extra ); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 129 | } |
| 130 | |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 131 | /*------------------------------------------------------------*/ |
| 132 | /*--- Suppressions ---*/ |
| 133 | /*------------------------------------------------------------*/ |
| 134 | |
njn | 810086f | 2002-11-14 12:42:47 +0000 | [diff] [blame] | 135 | Bool SK_(recognised_suppression) ( Char* name, Supp* su ) |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 136 | { |
njn | 810086f | 2002-11-14 12:42:47 +0000 | [diff] [blame] | 137 | SuppKind skind; |
sewardj | 99aac97 | 2002-12-26 01:53:45 +0000 | [diff] [blame] | 138 | |
njn | 43c799e | 2003-04-08 00:08:52 +0000 | [diff] [blame] | 139 | if (MAC_(shared_recognised_suppression)(name, su)) |
| 140 | return True; |
| 141 | |
| 142 | /* Extra suppressions not used by Addrcheck */ |
njn | 34419c1 | 2003-05-02 17:24:29 +0000 | [diff] [blame] | 143 | else if (VG_STREQ(name, "Cond")) skind = Value0Supp; |
| 144 | else if (VG_STREQ(name, "Value0")) skind = Value0Supp;/* backwards compat */ |
| 145 | else if (VG_STREQ(name, "Value1")) skind = Value1Supp; |
| 146 | else if (VG_STREQ(name, "Value2")) skind = Value2Supp; |
| 147 | else if (VG_STREQ(name, "Value4")) skind = Value4Supp; |
| 148 | else if (VG_STREQ(name, "Value8")) skind = Value8Supp; |
njn | c061666 | 2003-06-12 09:58:41 +0000 | [diff] [blame] | 149 | else if (VG_STREQ(name, "Value16")) skind = Value16Supp; |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 150 | else |
| 151 | return False; |
| 152 | |
njn | 810086f | 2002-11-14 12:42:47 +0000 | [diff] [blame] | 153 | VG_(set_supp_kind)(su, skind); |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 154 | return True; |
| 155 | } |
| 156 | |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 157 | /*--------------------------------------------------------------------*/ |
njn25 | cac76cb | 2002-09-23 11:21:57 +0000 | [diff] [blame] | 158 | /*--- end mc_errcontext.c ---*/ |
njn25 | e49d8e7 | 2002-09-23 09:36:25 +0000 | [diff] [blame] | 159 | /*--------------------------------------------------------------------*/ |