blob: c4f6b330f2172ae00edf561cc4d1470ee3d8fea7 [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- lldb.cpp ------------------------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "lldb/lldb-private.h"
11#include "lldb/lldb-private-log.h"
Eli Friedmane5cadba2010-06-13 19:36:42 +000012#include "lldb/Core/ArchSpec.h"
Stephen Wilson015eb232011-03-13 00:00:32 +000013#include "lldb/Core/Debugger.h"
Chris Lattner24943d22010-06-08 16:52:24 +000014#include "lldb/Core/Log.h"
Greg Clayton52fd9842011-02-02 02:24:04 +000015#include "lldb/Core/PluginManager.h"
Greg Claytone4b9c1f2011-03-08 22:40:15 +000016#include "lldb/Core/RegularExpression.h"
Chris Lattner24943d22010-06-08 16:52:24 +000017#include "lldb/Core/Timer.h"
18#include "lldb/Host/Host.h"
Eli Friedmane5cadba2010-06-13 19:36:42 +000019#include "lldb/Host/Mutex.h"
Greg Claytone01879a2010-12-16 21:36:30 +000020#include "lldb/Target/Target.h"
21#include "lldb/Target/Thread.h"
Eli Friedmane5cadba2010-06-13 19:36:42 +000022
Greg Claytone4b9c1f2011-03-08 22:40:15 +000023#include "llvm/ADT/StringRef.h"
24
Peter Collingbourneb7f59452011-05-19 18:32:34 +000025#include "Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.h"
26#include "Plugins/ABI/MacOSX-arm/ABIMacOSX_arm.h"
Peter Collingbourneaa9719a2011-05-19 17:34:40 +000027#include "Plugins/ABI/SysV-x86_64/ABISysV_x86_64.h"
Eli Friedmane5cadba2010-06-13 19:36:42 +000028#include "Plugins/Disassembler/llvm/DisassemblerLLVM.h"
Sean Callanan32a56ec2012-02-17 00:53:45 +000029#include "Plugins/Disassembler/llvm/DisassemblerLLVMC.h"
Caroline Tice080bf612011-04-05 18:46:00 +000030#include "Plugins/Instruction/ARM/EmulateInstructionARM.h"
Eli Friedmane5cadba2010-06-13 19:36:42 +000031#include "Plugins/SymbolVendor/MacOSX/SymbolVendorMacOSX.h"
32#include "Plugins/ObjectContainer/BSD-Archive/ObjectContainerBSDArchive.h"
33#include "Plugins/ObjectFile/ELF/ObjectFileELF.h"
34#include "Plugins/SymbolFile/DWARF/SymbolFileDWARF.h"
35#include "Plugins/SymbolFile/DWARF/SymbolFileDWARFDebugMap.h"
36#include "Plugins/SymbolFile/Symtab/SymbolFileSymtab.h"
Greg Clayton9a1941b2011-04-25 21:07:40 +000037#include "Plugins/UnwindAssembly/x86/UnwindAssembly-x86.h"
Greg Claytonf6e287a2011-04-25 21:05:07 +000038#include "Plugins/UnwindAssembly/InstEmulation/UnwindAssemblyInstEmulation.h"
Greg Claytone9f49822011-09-09 20:33:05 +000039#include "Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h"
Greg Clayton1fb32d12012-02-27 19:00:34 +000040#include "Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.h"
Greg Claytona605c642012-02-27 19:12:12 +000041#include "Plugins/Platform/FreeBSD/PlatformFreeBSD.h"
42#include "Plugins/Platform/Linux/PlatformLinux.h"
Greg Claytond815ded2012-08-23 21:17:11 +000043#ifndef LLDB_DISABLE_PYTHON
44#include "Plugins/OperatingSystem/Python/OperatingSystemPython.h"
45#endif
Greg Claytone4b9c1f2011-03-08 22:40:15 +000046#if defined (__APPLE__)
Eli Friedmane5cadba2010-06-13 19:36:42 +000047#include "Plugins/DynamicLoader/MacOSX-DYLD/DynamicLoaderMacOSXDYLD.h"
Greg Clayton17f3d052011-08-22 22:30:57 +000048#include "Plugins/DynamicLoader/Darwin-Kernel/DynamicLoaderDarwinKernel.h"
49#include "Plugins/OperatingSystem/Darwin-Kernel/OperatingSystemDarwinKernel.h"
Jim Ingham642036f2010-09-23 02:01:19 +000050#include "Plugins/LanguageRuntime/CPlusPlus/ItaniumABI/ItaniumABILanguageRuntime.h"
Jim Ingham2eac2b92010-11-04 18:30:59 +000051#include "Plugins/LanguageRuntime/ObjC/AppleObjCRuntime/AppleObjCRuntimeV1.h"
52#include "Plugins/LanguageRuntime/ObjC/AppleObjCRuntime/AppleObjCRuntimeV2.h"
Eli Friedmane5cadba2010-06-13 19:36:42 +000053#include "Plugins/ObjectContainer/Universal-Mach-O/ObjectContainerUniversalMachO.h"
54#include "Plugins/ObjectFile/Mach-O/ObjectFileMachO.h"
Greg Clayton8d2ea282011-07-17 20:36:25 +000055#include "Plugins/Process/MacOSX-Kernel/ProcessKDP.h"
Eli Friedmane5cadba2010-06-13 19:36:42 +000056#include "Plugins/Process/gdb-remote/ProcessGDBRemote.h"
Greg Claytone4b9c1f2011-03-08 22:40:15 +000057#include "Plugins/Platform/MacOSX/PlatformMacOSX.h"
Greg Claytonb1888f22011-03-19 01:12:21 +000058#include "Plugins/Platform/MacOSX/PlatformRemoteiOS.h"
Greg Claytonf96c8832012-02-25 06:56:35 +000059#include "Plugins/Platform/MacOSX/PlatformiOSSimulator.h"
Eli Friedmane5cadba2010-06-13 19:36:42 +000060#endif
Chris Lattner24943d22010-06-08 16:52:24 +000061
Greg Clayton46c9a352012-02-09 06:16:32 +000062#include "Plugins/Process/mach-core/ProcessMachCore.h"
63
Greg Claytone4b9c1f2011-03-08 22:40:15 +000064#if defined (__linux__)
Greg Claytone4b9c1f2011-03-08 22:40:15 +000065#include "Plugins/Process/Linux/ProcessLinux.h"
Stephen Wilsonf6f40332010-07-24 02:19:04 +000066#endif
67
Johnny Chen4b663292011-08-02 20:52:42 +000068#if defined (__FreeBSD__)
Johnny Chen78dae822012-04-14 00:54:42 +000069#include "Plugins/Process/gdb-remote/ProcessGDBRemote.h"
Johnny Chen7e996472012-01-05 19:17:38 +000070#include "Plugins/Process/POSIX/ProcessPOSIX.h"
71#include "Plugins/Process/FreeBSD/ProcessFreeBSD.h"
Johnny Chen4b663292011-08-02 20:52:42 +000072#endif
73
Greg Clayton58e26e02011-03-24 04:28:38 +000074#include "Plugins/Platform/gdb-server/PlatformRemoteGDBServer.h"
Greg Claytonbd321c52011-03-05 01:04:56 +000075#include "Plugins/DynamicLoader/Static/DynamicLoaderStatic.h"
76
Greg Claytonadb909b2010-12-16 21:33:41 +000077using namespace lldb;
Chris Lattner24943d22010-06-08 16:52:24 +000078using namespace lldb_private;
79
Chris Lattner24943d22010-06-08 16:52:24 +000080void
81lldb_private::Initialize ()
82{
83 // Make sure we inialize only once
Caroline Tice0aa2e552011-01-14 00:29:16 +000084 static Mutex g_inited_mutex(Mutex::eMutexTypeRecursive);
Chris Lattner24943d22010-06-08 16:52:24 +000085 static bool g_inited = false;
86
87 Mutex::Locker locker(g_inited_mutex);
88 if (!g_inited)
89 {
90 g_inited = true;
Greg Clayton990de7b2010-11-18 23:32:35 +000091 Log::Initialize();
Chris Lattner24943d22010-06-08 16:52:24 +000092 Timer::Initialize ();
93 Timer scoped_timer (__PRETTY_FUNCTION__, __PRETTY_FUNCTION__);
Greg Clayton990de7b2010-11-18 23:32:35 +000094
Peter Collingbourneb7f59452011-05-19 18:32:34 +000095 ABIMacOSX_i386::Initialize();
96 ABIMacOSX_arm::Initialize();
Peter Collingbourneaa9719a2011-05-19 17:34:40 +000097 ABISysV_x86_64::Initialize();
Sean Callanan32a56ec2012-02-17 00:53:45 +000098 DisassemblerLLVMC::Initialize();
Chris Lattner24943d22010-06-08 16:52:24 +000099 DisassemblerLLVM::Initialize();
Chris Lattner24943d22010-06-08 16:52:24 +0000100 ObjectContainerBSDArchive::Initialize();
101 ObjectFileELF::Initialize();
Chris Lattner24943d22010-06-08 16:52:24 +0000102 SymbolFileDWARF::Initialize();
Chris Lattner24943d22010-06-08 16:52:24 +0000103 SymbolFileSymtab::Initialize();
Greg Claytonf6e287a2011-04-25 21:05:07 +0000104 UnwindAssemblyInstEmulation::Initialize();
Greg Clayton888a7332011-04-26 04:39:08 +0000105 UnwindAssembly_x86::Initialize();
Caroline Tice080bf612011-04-05 18:46:00 +0000106 EmulateInstructionARM::Initialize ();
Greg Claytone9f49822011-09-09 20:33:05 +0000107 ObjectFilePECOFF::Initialize ();
Bill Wendling0fd911c2012-04-05 17:38:07 +0000108 DynamicLoaderPOSIXDYLD::Initialize ();
Greg Claytona605c642012-02-27 19:12:12 +0000109 PlatformFreeBSD::Initialize();
110 PlatformLinux::Initialize();
Greg Claytond815ded2012-08-23 21:17:11 +0000111#ifndef LLDB_DISABLE_PYTHON
112 OperatingSystemPython::Initialize();
113#endif
114
Greg Claytone4b9c1f2011-03-08 22:40:15 +0000115#if defined (__APPLE__)
Greg Clayton58e26e02011-03-24 04:28:38 +0000116 //----------------------------------------------------------------------
117 // Apple/Darwin hosted plugins
118 //----------------------------------------------------------------------
Eli Friedmane5cadba2010-06-13 19:36:42 +0000119 DynamicLoaderMacOSXDYLD::Initialize();
Greg Clayton17f3d052011-08-22 22:30:57 +0000120 DynamicLoaderDarwinKernel::Initialize();
121 OperatingSystemDarwinKernel::Initialize();
Stephen Wilsonbe1acb22011-01-12 04:22:09 +0000122 SymbolFileDWARFDebugMap::Initialize();
Jim Ingham642036f2010-09-23 02:01:19 +0000123 ItaniumABILanguageRuntime::Initialize();
124 AppleObjCRuntimeV2::Initialize();
Jim Ingham2eac2b92010-11-04 18:30:59 +0000125 AppleObjCRuntimeV1::Initialize();
Eli Friedmane5cadba2010-06-13 19:36:42 +0000126 ObjectContainerUniversalMachO::Initialize();
127 ObjectFileMachO::Initialize();
128 ProcessGDBRemote::Initialize();
Jason Molenda5d673ae2012-06-01 01:39:46 +0000129 ProcessKDP::Initialize();
Greg Clayton46c9a352012-02-09 06:16:32 +0000130 ProcessMachCore::Initialize();
Stephen Wilsonf6f40332010-07-24 02:19:04 +0000131 SymbolVendorMacOSX::Initialize();
Greg Claytonb1888f22011-03-19 01:12:21 +0000132 PlatformRemoteiOS::Initialize();
Greg Claytonb1db6582012-03-20 18:34:04 +0000133 PlatformMacOSX::Initialize();
Greg Claytonf96c8832012-02-25 06:56:35 +0000134 PlatformiOSSimulator::Initialize();
Stephen Wilsonf6f40332010-07-24 02:19:04 +0000135#endif
Greg Claytone4b9c1f2011-03-08 22:40:15 +0000136#if defined (__linux__)
Greg Clayton58e26e02011-03-24 04:28:38 +0000137 //----------------------------------------------------------------------
138 // Linux hosted plugins
139 //----------------------------------------------------------------------
Stephen Wilsonf6f40332010-07-24 02:19:04 +0000140 ProcessLinux::Initialize();
Eli Friedmane5cadba2010-06-13 19:36:42 +0000141#endif
Johnny Chen4b663292011-08-02 20:52:42 +0000142#if defined (__FreeBSD__)
Johnny Chen7e996472012-01-05 19:17:38 +0000143 ProcessFreeBSD::Initialize();
Johnny Chen78dae822012-04-14 00:54:42 +0000144 ProcessGDBRemote::Initialize();
Johnny Chen4b663292011-08-02 20:52:42 +0000145#endif
Greg Clayton58e26e02011-03-24 04:28:38 +0000146 //----------------------------------------------------------------------
147 // Platform agnostic plugins
148 //----------------------------------------------------------------------
149 PlatformRemoteGDBServer::Initialize ();
Greg Claytonbd321c52011-03-05 01:04:56 +0000150 DynamicLoaderStatic::Initialize();
Greg Clayton58e26e02011-03-24 04:28:38 +0000151
Greg Clayton52fd9842011-02-02 02:24:04 +0000152 // Scan for any system or user LLDB plug-ins
153 PluginManager::Initialize();
Greg Claytond284b662011-02-18 01:44:25 +0000154
Caroline Tice2a456812011-03-10 22:14:10 +0000155 // The process settings need to know about installed plug-ins, so the Settings must be initialized
156 // AFTER PluginManager::Initialize is called.
157
158 Debugger::SettingsInitialize();
Chris Lattner24943d22010-06-08 16:52:24 +0000159 }
160}
161
162void
163lldb_private::WillTerminate()
164{
165 Host::WillTerminate();
166}
167
168void
169lldb_private::Terminate ()
170{
171 Timer scoped_timer (__PRETTY_FUNCTION__, __PRETTY_FUNCTION__);
Greg Clayton52fd9842011-02-02 02:24:04 +0000172
173 // Terminate and unload and loaded system or user LLDB plug-ins
174 PluginManager::Terminate();
175
Peter Collingbourneb7f59452011-05-19 18:32:34 +0000176 ABIMacOSX_i386::Terminate();
177 ABIMacOSX_arm::Terminate();
Peter Collingbourneaa9719a2011-05-19 17:34:40 +0000178 ABISysV_x86_64::Terminate();
Sean Callanan32a56ec2012-02-17 00:53:45 +0000179 DisassemblerLLVMC::Terminate();
Chris Lattner24943d22010-06-08 16:52:24 +0000180 DisassemblerLLVM::Terminate();
Chris Lattner24943d22010-06-08 16:52:24 +0000181 ObjectContainerBSDArchive::Terminate();
182 ObjectFileELF::Terminate();
Chris Lattner24943d22010-06-08 16:52:24 +0000183 SymbolFileDWARF::Terminate();
Chris Lattner24943d22010-06-08 16:52:24 +0000184 SymbolFileSymtab::Terminate();
Greg Claytonf6e287a2011-04-25 21:05:07 +0000185 UnwindAssembly_x86::Terminate();
186 UnwindAssemblyInstEmulation::Terminate();
Caroline Tice080bf612011-04-05 18:46:00 +0000187 EmulateInstructionARM::Terminate ();
Greg Claytone9f49822011-09-09 20:33:05 +0000188 ObjectFilePECOFF::Terminate ();
Bill Wendling0fd911c2012-04-05 17:38:07 +0000189 DynamicLoaderPOSIXDYLD::Terminate ();
Greg Claytona605c642012-02-27 19:12:12 +0000190 PlatformFreeBSD::Terminate();
191 PlatformLinux::Terminate();
Greg Claytond815ded2012-08-23 21:17:11 +0000192#ifndef LLDB_DISABLE_PYTHON
193 OperatingSystemPython::Terminate();
194#endif
195
Greg Claytone4b9c1f2011-03-08 22:40:15 +0000196#if defined (__APPLE__)
Eli Friedmane5cadba2010-06-13 19:36:42 +0000197 DynamicLoaderMacOSXDYLD::Terminate();
Greg Clayton17f3d052011-08-22 22:30:57 +0000198 DynamicLoaderDarwinKernel::Terminate();
199 OperatingSystemDarwinKernel::Terminate();
Stephen Wilsonbe1acb22011-01-12 04:22:09 +0000200 SymbolFileDWARFDebugMap::Terminate();
Jim Ingham2eac2b92010-11-04 18:30:59 +0000201 ItaniumABILanguageRuntime::Terminate();
202 AppleObjCRuntimeV2::Terminate();
203 AppleObjCRuntimeV1::Terminate();
Eli Friedmane5cadba2010-06-13 19:36:42 +0000204 ObjectContainerUniversalMachO::Terminate();
205 ObjectFileMachO::Terminate();
Greg Clayton46c9a352012-02-09 06:16:32 +0000206 ProcessMachCore::Terminate();
Eli Friedmane5cadba2010-06-13 19:36:42 +0000207 ProcessGDBRemote::Terminate();
Jason Molenda5d673ae2012-06-01 01:39:46 +0000208 ProcessKDP::Terminate();
Stephen Wilsonf6f40332010-07-24 02:19:04 +0000209 SymbolVendorMacOSX::Terminate();
Greg Claytone4b9c1f2011-03-08 22:40:15 +0000210 PlatformMacOSX::Terminate();
Greg Claytonb1888f22011-03-19 01:12:21 +0000211 PlatformRemoteiOS::Terminate();
Greg Claytonf96c8832012-02-25 06:56:35 +0000212 PlatformiOSSimulator::Terminate();
Stephen Wilsonf6f40332010-07-24 02:19:04 +0000213#endif
214
Caroline Tice2a456812011-03-10 22:14:10 +0000215 Debugger::SettingsTerminate ();
Greg Clayton990de7b2010-11-18 23:32:35 +0000216
Greg Claytone4b9c1f2011-03-08 22:40:15 +0000217#if defined (__linux__)
Stephen Wilsonf6f40332010-07-24 02:19:04 +0000218 ProcessLinux::Terminate();
Eli Friedmane5cadba2010-06-13 19:36:42 +0000219#endif
Johnny Chen4b663292011-08-02 20:52:42 +0000220
221#if defined (__FreeBSD__)
Johnny Chen7e996472012-01-05 19:17:38 +0000222 ProcessFreeBSD::Terminate();
Johnny Chen78dae822012-04-14 00:54:42 +0000223 ProcessGDBRemote::Terminate();
Johnny Chen4b663292011-08-02 20:52:42 +0000224#endif
Greg Claytonbd321c52011-03-05 01:04:56 +0000225
226 DynamicLoaderStatic::Terminate();
Greg Clayton990de7b2010-11-18 23:32:35 +0000227
228 Log::Terminate();
Chris Lattner24943d22010-06-08 16:52:24 +0000229}
230
Greg Claytone86cbb92011-03-22 01:14:58 +0000231extern "C" const double liblldb_coreVersionNumber;
Chris Lattner24943d22010-06-08 16:52:24 +0000232const char *
233lldb_private::GetVersion ()
234{
Chris Lattner24943d22010-06-08 16:52:24 +0000235 static char g_version_string[32];
236 if (g_version_string[0] == '\0')
Greg Claytone86cbb92011-03-22 01:14:58 +0000237 ::snprintf (g_version_string, sizeof(g_version_string), "LLDB-%g", liblldb_coreVersionNumber);
Chris Lattner24943d22010-06-08 16:52:24 +0000238
239 return g_version_string;
240}
241
Greg Clayton5205f0b2010-09-03 17:10:42 +0000242const char *
Greg Claytonb3448432011-03-24 21:19:54 +0000243lldb_private::GetVoteAsCString (Vote vote)
Greg Clayton5205f0b2010-09-03 17:10:42 +0000244{
Greg Claytonf04d6612010-09-03 22:45:01 +0000245 switch (vote)
246 {
247 case eVoteNo: return "no";
248 case eVoteNoOpinion: return "no opinion";
249 case eVoteYes: return "yes";
250 default:
251 break;
252 }
Greg Clayton5205f0b2010-09-03 17:10:42 +0000253 return "invalid";
254}
255
Greg Clayton3fed8b92010-10-08 00:21:05 +0000256
257const char *
Greg Claytonb3448432011-03-24 21:19:54 +0000258lldb_private::GetSectionTypeAsCString (SectionType sect_type)
Greg Clayton3fed8b92010-10-08 00:21:05 +0000259{
260 switch (sect_type)
261 {
262 case eSectionTypeInvalid: return "invalid";
263 case eSectionTypeCode: return "code";
264 case eSectionTypeContainer: return "container";
265 case eSectionTypeData: return "data";
266 case eSectionTypeDataCString: return "data-cstr";
267 case eSectionTypeDataCStringPointers: return "data-cstr-ptr";
268 case eSectionTypeDataSymbolAddress: return "data-symbol-addr";
269 case eSectionTypeData4: return "data-4-byte";
270 case eSectionTypeData8: return "data-8-byte";
271 case eSectionTypeData16: return "data-16-byte";
272 case eSectionTypeDataPointers: return "data-ptrs";
273 case eSectionTypeDebug: return "debug";
274 case eSectionTypeZeroFill: return "zero-fill";
275 case eSectionTypeDataObjCMessageRefs: return "objc-message-refs";
276 case eSectionTypeDataObjCCFStrings: return "objc-cfstrings";
277 case eSectionTypeDWARFDebugAbbrev: return "dwarf-abbrev";
278 case eSectionTypeDWARFDebugAranges: return "dwarf-aranges";
279 case eSectionTypeDWARFDebugFrame: return "dwarf-frame";
280 case eSectionTypeDWARFDebugInfo: return "dwarf-info";
281 case eSectionTypeDWARFDebugLine: return "dwarf-line";
282 case eSectionTypeDWARFDebugLoc: return "dwarf-loc";
283 case eSectionTypeDWARFDebugMacInfo: return "dwarf-macinfo";
284 case eSectionTypeDWARFDebugPubNames: return "dwarf-pubnames";
285 case eSectionTypeDWARFDebugPubTypes: return "dwarf-pubtypes";
286 case eSectionTypeDWARFDebugRanges: return "dwarf-ranges";
287 case eSectionTypeDWARFDebugStr: return "dwarf-str";
Greg Claytonf6e3de22011-09-28 17:06:40 +0000288 case eSectionTypeDWARFAppleNames: return "apple-names";
289 case eSectionTypeDWARFAppleTypes: return "apple-types";
Greg Clayton00db2152011-10-04 22:41:51 +0000290 case eSectionTypeDWARFAppleNamespaces: return "apple-namespaces";
Greg Clayton24a6bd92011-10-27 17:55:14 +0000291 case eSectionTypeDWARFAppleObjC: return "apple-objc";
Greg Clayton3fed8b92010-10-08 00:21:05 +0000292 case eSectionTypeEHFrame: return "eh-frame";
293 case eSectionTypeOther: return "regular";
294 }
295 return "unknown";
296
297}
298
Greg Claytone4b9c1f2011-03-08 22:40:15 +0000299bool
300lldb_private::NameMatches (const char *name,
Greg Claytonb3448432011-03-24 21:19:54 +0000301 NameMatchType match_type,
Greg Claytone4b9c1f2011-03-08 22:40:15 +0000302 const char *match)
303{
304 if (match_type == eNameMatchIgnore)
305 return true;
306
307 if (name == match)
308 return true;
309
310 if (name && match)
311 {
312 llvm::StringRef name_sref(name);
313 llvm::StringRef match_sref(match);
314 switch (match_type)
315 {
316 case eNameMatchIgnore:
317 return true;
318 case eNameMatchEquals: return name_sref == match_sref;
319 case eNameMatchContains: return name_sref.find (match_sref) != llvm::StringRef::npos;
320 case eNameMatchStartsWith: return name_sref.startswith (match_sref);
321 case eNameMatchEndsWith: return name_sref.endswith (match_sref);
322 case eNameMatchRegularExpression:
323 {
324 RegularExpression regex (match);
325 return regex.Execute (name);
326 }
327 break;
328 default:
329 assert (!"unhandled NameMatchType in lldb_private::NameMatches()");
330 break;
331 }
332 }
333 return false;
334}