12010-01-29 Greg Clayton <gclayton@apple.com> 2 3 * MachProcess.cpp (MachProcess::PrepareForAttach): No longer use the 4 SBSLaunchApplication macro from the SpringBoard.framework, use the actual 5 function name SBSLaunchApplicationForDebugging. 6 (MachProcess::CleanupAfterAttach): Ditto. 7 (MachProcess::SBForkChildForPTraceDebugging): Ditto. 8 (debugserver-entitlements.plist): Added the "seatbelt-profiles" entitlement 9 so debugserver can be sandboxed. 10 112009-07-06 Greg Clayton <gclayton@apple.com> 12 13 * MachTask.cpp (MachTask::GetDYLDAllImageInfosAddress): Hack around bad 14 kernel code that renamed the first member of the TASK_DYLD_INFO without 15 any way to detect it has changed. 16 172009-06-29 Greg Clayton <gclayton@apple.com> 18 19 * DNB.cpp (GetAllInfosMatchingName): Correctly truncate process name string 20 to MAXCOMLEN when searching kinfo_proc structs for process matches by name. 21 * MachProcess.cpp (MachProcess::PrepareForAttach): Added logging when 22 attaching to a program by name. 23 242009-06-25 Greg Clayton <gclayton@apple.com> 25 26 * DNB.cpp (DNBProcessLaunch): Added a stat on the incoming path that we are 27 about to launch to make sure the file exists. If the file doesn't, then an 28 appropriate error string is returned. Also if we fail to get the task for 29 our process ID, we return an error string right away instead of letting the 30 debug session go for a little bit and then later failing after a few more 31 packets. 32 332009-04-07 Jim Ingham <jingham@apple.com> 34 35 * RNBRemote.h: Add vAttachWait 36 * RNBRemote.cpp (RNBRemote::CreatePacketTable): Add vattachwait. 37 (RNBRemoteShouldCancelCallback): New function. 38 (RNBRemote::HandlePacket_v): Handle vattachwait. 39 * RNBSocket.cpp (RNBSocket::Read): Mark the connection as closed when the 40 port goes away. 41 * DNB.cpp (DNBProcessAttachByName): New function. 42 (DNBProcessAttach): Make this handle catching the attach when done and 43 dealing with timeout & return conditions. 44 (GetAllInfos): New function. 45 (GetAlInfosMatchingName): New function. 46 (DNBProcessAttachWait): New function. 47 DNB.h: Declare DNBProcessAttachByName, DNBProcessAttachWait, change 48 signature of DNBProcessAttach. 49 * MachProcess.cpp (MachProcess::PrepareForAttach): New function. 50 (MachProcess::CheckForProcess): New function. 51 (MachProcess::CleanupAfterAttach): New function. 52 (CopyBundleIDForPath): New function. 53 (MachProcess::SBForkChildForPTraceDebugging): Convert to using 54 CopyBundleIDForPath. 55 * MachProcess.h: Declare PrepareForAttach, CleanupAfterAttach and 56 CheckForProcess. 57 * DNBTimer.h (TimeOfDayLaterThan): New function. 58 * test-remotenub.cpp (RNBRunLoopGetStartModeFromRemote): Rename from 59 RNBRunLoopGetArgsFromRemote, and handle vattachwait. 60 (RNBRunLoopLaunchAttaching): Code was moved from here into DNBProcessAttach. 61 (StartListening): New function. 62 (GetAllProcessInfos, GetAllProcessInfosMatchingName): Moved to 63 DNBProcess.cpp. 64 (main): Handle attach waitfor, and make debugserver with only a host and 65 port wait on commands from gdb. 66 672009-04-03 Greg Clayton <gclayton@apple.com> 68 69 * RNBRemote.h (PacketEnum): Added enum for qShlibInfoAddr. 70 * RNBRemote.cpp (RNBRemote::CreatePacketTable) Added the qShlibInfoAddr 71 packet definition to m_packets. 72 (RNBRemote::GetPacket): Log when we run into an unimplemented packet. 73 (RNBRemote::HandleReceivedPacket): Only log the packet when logging 74 LOG_RNB_REMOTE. 75 (RNBRemote::HandlePacket_q): Add support for the new qShlibInfoAddr packet. 76 * DNB.h (DNBProcessGetSharedLibraryInfoAddress): New prototype. 77 * DNB.cpp (DNBProcessGetSharedLibraryInfoAddress): New function. 78 * MachTask.h (MachProcess::GetDYLDAllImageInfosAddress): New prototype. 79 * MachTask.cpp (MachProcess::GetDYLDAllImageInfosAddress): New function. 80 812009-04-01 Greg Clayton <gclayton@apple.com> 82 83 * test-remotenub.cpp (main): Display the detailed error message if any when 84 attaching fails. 85 862009-03-25 Greg Clayton <gclayton@apple.com> 87 88 * test-remotenub.cpp (RNBRunLoopGetArgsFromRemote): Cleaned up logging and 89 removed time deltas form the messages. 90 (RNBRunLoopLaunchAttaching): Ditto. 91 (RNBRunLoopLaunchInferior): Ditto and also use new DNBProcessLaunch that 92 takes an error string pointer. 93 * RNBContext.h (class RNBContext): Removed the m_timer member. 94 * RNBContext.cpp (RNBContext::StartProcessStatusThread): Cleaned up logging 95 and removed time deltas form the messages. 96 (RNBContext::ThreadFunctionProcessStatus): Ditto. 97 * RNBSocket.h (class RNBSocket): Removed unused m_last_errno member and 98 accessor functions. 99 * RNBSocket.cpp (RNBSocket::Listen): Cleaned up logging and 100 removed time deltas form the messages. 101 (RNBSocket::ConnectToService): Ditto. 102 (RNBSocket::Read): Ditto. 103 (RNBSocket::Write): Ditto. 104 (RNBSocket::SaveErrno): Removed. 105 (RNBSocket::ClosePort): Don't call RNBSocket::SaveErrno(). 106 * RNBRemote.cpp (RNBRemote::RNBRemote): Cleaned up logging and 107 removed time deltas form the messages. 108 (RNBRemote::~RNBRemote): Ditto. 109 (RNBRemote::SendPacket): Ditto. 110 (RNBRemote::GetPacketPayload): Ditto. 111 (RNBRemote::GetPacket): Ditto): Ditto. 112 (RNBRemote::HandleAsyncPacket): Ditto. 113 (RNBRemote::HandleReceivedPacket): Ditto. 114 (RNBRemote::CommDataReceived): Ditto. 115 * DNB.cpp (DNBProcessLaunch): Changed to take a eror string pointer with 116 size for more desciptive error reporting (instead of a uint32_t pointer). 117 * DNB.h (DNBProcessLaunch): Ditto. 118 * DNBError.cpp (DNBError::AsString): Now returns NULL if there is no error. 119 * DNBError.h (DNBError::SetErrorString): New accessor to allow custom error 120 strings. 121 * arm/DNBArchImpl.cpp (DNBArchMachARM::GetGPRState): Improved logging. 122 * MachProcess.cpp (MachProcess::SBForkChildForPTraceDebugging): Improved 123 error messages when a file doesn't exist, or when unable to extract the 124 CFBundleIdentifier. 125 * PThreadEvent.cpp (class PThreadEvent): Commented out all logging calls. 126 1272009-03-07 Greg Clayton <gclayton@apple.com> 128 129 * test-remotenub.cpp (GetAllProcessInfosMatchingName): New function that 130 returns matching kinfo_proc structs given a process name. 131 (main): Enhanced the --attach option to be able to take a PROCNAME or 132 a PID. Changed the --waitfor=PROCNAME option to ignore any existing 133 processes with PROCNAME so we only catch new process invocations. 134 1352009-03-07 Greg Clayton <gclayton@apple.com> 136 137 * RNBRemote.cpp (RNBRemote::HandlePacket_p): Use the correct get current 138 thread function call so we get the correct thread registers. 139 1402009-03-03 Greg Clayton <gclayton@apple.com> 141 142 * test-remotenub.cpp (g_isatty): New global that gets set to non-zero if 143 STDOUT is a TTY in the beginning of main. 144 (RNBLogSTDOUT): New macro that logs to STDOUT if g_isatty is non-zero, else 145 it logs to asl. 146 (RNBLogSTDERR): New macro that logs to STDERR if g_isatty is non-zero, else 147 it logs to asl. 148 (RNBRunLoopGetArgsFromRemote): Use new RNBLogSTDOUT/RNBLogSTDERR macros. 149 (GetAllProcessInfos): Get all process info structs for everything on the 150 system. 151 (main): Implemented new --waitfor=NAME option to allow waiting for a process 152 to run by polling the system processes. The new --waitfor-interval=N option 153 allows fine control over the polling interval where N is the number of mirco 154 seconds (usec) to wait between polls (defaults to 1000). The new 155 --waitfor-duration=N allows a timeout in seconds to be specified when 156 waiting for a process (defaults to infinite). 157 1582009-03-02 Greg Clayton <gclayton@apple.com> 159 160 * DNBArchImpl.cpp (DNBArchMachARM::EvaluateNextInstructionForSoftwareBreakpointSetup): 161 Take care of a case where no instructions execute in a Thumb IT block and 162 the last of which is a branch. 163 1642009-02-10 Greg Clayton <gclayton@apple.com> 165 166 * RNBRemote.h (PacketEnum): Added 'detach' enumeration. 167 (RNBRemote::HandlePacket_D): New member function prototype. 168 * RNBRemote.cpp (RNBRemote::CreatePacketTable): Added detach support. 169 (RNBRemote::HandlePacket_D): New function for detach support. 170 1712009-02-10 Greg Clayton <gclayton@apple.com> 172 173 * RNBRemote.cpp (RNBRemote::HandlePacket_UNIMPLEMENTED): Log this 174 packet with the packet that is unimplemented. 175 (RNBRemote::GetPacket): Call RNBRemote::HandlePacket_UNIMPLEMENTED() 176 when we don't recognize a packet. 177 (RNBRemote::HandleReceivedPacket): Don't reply to packets we don't 178 recognize with unimplemented in this function as that should have 179 already been done for us in RNBRemote::GetPacket(). 180 1812009-02-10 Greg Clayton <gclayton@apple.com> 182 183 * RNBRemote.h (PacketEnum): Added query_step_packet_supported. 184 * RNBRemot.cpp (RNBRemote::CreatePacketTable): Added new 185 qStepPacketSupported packet. 186 (RNBRemote::HandlePacket_q): Added support for the new 187 "qStepPacketSupported" packet. 188 (RNBRemote::HandlePacket_G): Some cleanup when reading registers 189 to avoid spurious console logging. 190 1912009-01-30 Greg Clayton <gclayton@apple.com> 192 193 * debugserver-entitlements.plist: Changed the entitlement 194 "run-invalid-allow" to "run-unsigned-code". 195 1962009-01-23 Greg Clayton <gclayton@apple.com> 197 198 * DNBArchImpl.cpp (DNBArchMachARM::EvaluateNextInstructionForSoftwareBreakpointSetup): 199 Merged Yusuf's changes to make software single stepping work. 200 * test-remotenub.cpp (RNBRunLoopLaunchInferior): Call new 201 DNBResolveExecutablePath function to resolve executable paths. 202 * DNB.h (DNBResolveExecutablePath): New function prototype. 203 * DNB.cpp (DNBResolveExecutablePath): New function that will resolve 204 relative paths and also executable paths for executables that aren't relative 205 but yet are in the shell PATH environment variable. 206 2072009-01-22 Greg Clayton <gclayton@apple.com> 208 209 * DNBArchImpl.h (class DBNArchMachARM): Renamed member variable 210 m_chained_hw_single_step_addr to m_hw_single_chained_step_addr. Added 211 new member variables: m_sw_single_step_itblock_break_id, m_last_decode_pc, 212 and m_sw_single_step_itblock_break_count. Renamed m_thumbStaticData to 213 m_last_decode_thumb, and renamed m_decodedInstruction to m_last_decode_arm. 214 (DBNArchMachARM::DecodeITBlockInstructions): New prototype. 215 (DBNArchMachARM::DecodeInstructionUsingDisassembler): New prototype. 216 (DBNArchMachARM::BreakpointHit): New prototype. 217 * DNBArchImpl.cpp (DNBArchMachARM::ThreadDidStop): Disable any of the 218 many software single step breakpoints if any are set. 219 (DNBArchMachARM::StepNotComplete): Changed renamed member accesses. 220 (DNBArchMachARM::DecodeITBlockInstructions): New function for software 221 single stepping through Thumb IT blocks. 222 (DNBArchMachARM::EnableHardwareSingleStep): Cleaned up logging. 223 (DNBArchMachARM::ComputeNextPC): Ditto. 224 (DNBArchMachARM::EvaluateNextInstructionForSoftwareBreakpointSetup): Now 225 properly handles Thumb IT software single stepping. 226 (DNBArchMachARM::SetSingleStepSoftwareBreakpoints): Ditto. 227 (DNBArchMachARM::DecodeInstructionUsingDisassembler): New function. 228 (DNBArchMachARM::BreakpointHit): New breakpoint callback function. 229 2302009-01-21 Greg Clayton <gclayton@apple.com> 231 232 * MachProcess.cpp (MachProcess::PrivateResume): Set the process state before 233 we actually resume so we are sure to get the events in the correct order. 234 2352009-01-16 Greg Clayton <gclayton@apple.com> 236 237 * RNBRemote.cpp (RNBRemote::HandlePacket_last_signal): Include only 238 registers which are to be expedited in the T packets. 239 (RNBRemote::HandlePacket_p): Enable for all targets. 240 (struct register_map_entry): Added an expedite member so we know which 241 registers need to be sent up to the host with each stop reply packet. 242 (register_map): Updated each array members' expedite member with an 243 appropriate value. 244 2452009-01-16 Greg Clayton <gclayton@apple.com> 246 247 * RNBRemote.cpp (RNBRemote::HandlePacket_s): Enabled the step command ("s" 248 packet) for ARM now that libdebugnub.dylib can do both hardware and software 249 single stepping. 250 2512009-01-13 Greg Clayton <gclayton@apple.com> 252 253 *DNBArchImpl.cpp (bit): New function. 254 (bits): New function. 255 (DNBArchMachARM::ConditionPassed): Use new "bit" function. 256 (DNBArchMachARM::ComputeNextPC): Use new "bit" function, remove inline 257 assembly for "RSC" instruction so this compiles for armv7 (which defaults 258 to thumb) 259 (DNBArchMachARM::NumSupportedHardwareBreakpoints): Use new "bits" function. 260 (DNBArchMachARM::NumSupportedHardwareWatchpoints): Use new "bits" function. 261 2622009-01-12 Greg Clayton <gclayton@apple.com> 263 264 * DNBArch.h (DNBArchProtocol::NumSupportedHardwareBreakpoints()): Removed 265 the "const" qualifier to allow arches to auto detect how many hardware 266 breakpoints they have. 267 (DNBArchProtocol::NumSupportedHardwareWatchpoints()): Removed the "const" 268 qualifier to allow arches to auto detect how many hardware watchpoints they 269 have. 270 * DNBArchImpl.h (DNBArchMachARM::NumSupportedHardwareBreakpoints()): Auto 271 detect how many BRP pairs are avialable and disable for armv7 for the time 272 being (rdar://problem/6372672). 273 (DNBArchMachARM::NumSupportedHardwareWatchpoints()): Auto detect how many 274 WRP pairs are avialable and disable for armv7 for the time being 275 (rdar://problem/6372672). 276 2772009-01-09 Greg Clayton <gclayton@apple.com> 278 279 * test-remotenub.cpp (main): Filled in short argument versions for 280 --applist (-t) and --lockdown (-k) options. 281 * DNBArchImpl.h (DNBArchMachARM::ConditionPassed): New protected 282 member function. 283 (DNBArchMachARM::ComputeNextPC): New protected member function. 284 (DNBArchMachARM::EvaluateNextInstructionForSoftwareBreakpointSetup): New 285 protected member function. 286 (DNBArchMachARM::m_thumbStaticData): New protected member variable. 287 (DNBArchMachARM::m_decodedInstruction): New protected member variable. 288 * DNBArchImpl.cpp (DNBArchMachARM::ThreadDidStop): Added extra code that 289 will log and exit when we are verifying software single stepping (a 290 compile time option). 291 (DNBArchMachARM::ConditionPassed): New function. 292 (DNBArchMachARM::ComputeNextPC): New function. 293 (DNBArchMachARM::EvaluateNextInstructionForSoftwareBreakpointSetup): New 294 function. 295 (DNBArchMachARM::SetSingleStepSoftwareBreakpoints): Added the guts of the 296 software single stepping. 297 (DNBArchMachARM::NumSupportedHardwareBreakpoints): Prepared for adding 298 auto detection code. 299 (DNBArchMachARM::NumSupportedHardwareWatchpoints): Prepared for adding 300 auto detection code. 301 3022008-12-11 Greg Clayton <gclayton@apple.com> 303 304 * DNB.h (DNBProcessWaitForEvent): Renamed to DNBProcessWaitForEvents. 305 (DNBProcessSetEvents): Removed (deprecated). 306 (DNBProcessGetWaitForResetMask): Removed (unused). 307 (DNBProcessSetWaitForResetMask): Removed (unused). 308 (DNBProcessInterruptEvents): New function prototype. 309 * DNB.cpp (DNBProcessWaitForEvent): Renamed to DNBProcessWaitForEvents. 310 (DNBProcessSetEvents): Removed (deprecated). 311 (DNBProcessGetWaitForResetMask): Removed (unused). 312 (DNBProcessSetWaitForResetMask): Removed (unused). 313 (DNBProcessInterruptEvents): New function that can be used to 314 asynchronously interrupt infinite wait for events calls. 315 RNBRemote.cpp (RNBRemote::HandlePacket_v): Call DNBProcessWaitForEvents. 316 RNBContext.cpp (RNBContext::ThreadFunctionProcessStatus): Ditto. 317 test-remotenub.cpp (RNBRunLoopLaunchInferior): Ditto. 318 (RNBRunLoopLaunchAttaching): Ditto. 319 3202008-12-11 Greg Clayton <gclayton@apple.com> 321 322 * DNB.cpp (GetProcessMap): Use new PTHREAD_MUTEX_LOCKER macro to ease 323 debugging of deadlocks. 324 (DNBProcessLaunch): Improved logging. 325 (DNBProcessMemoryRead): Call MachProcess::ReadMemory so breakpoint 326 opcodes can be removed from memory. 327 (DNBProcessMemoryWrite): Call MachProcess::WriteMemory so that we work 328 around enabled software breakpoint traps. 329 * DNBLog.cpp (GetLogThreadedMutex): New function. 330 (_DNBLogThreaded): Use new PTHREAD_MUTEX_LOCKER macro to ease 331 debugging of deadlocks. 332 (_DNBLogThreadedIf): Ditto. 333 * DNBBreakpoint.h (DNBBreakpoint::IntersectsRange): New function. 334 * DNBBreakpoint.cpp (DNBBreakpointList::FindIDByAddress): Improved 335 logging. 336 * MacOSX/MachThread.cpp (MachThread::MachThread): Improved logging. 337 (MachThread::~MachThread): Ditto. 338 (MachThread::Suspend): Ditto. 339 (MachThread::Resume): Ditto. 340 (MachThread::RestoreSuspendCount): Ditto. 341 (MachThread::GetState): Use new PTHREAD_MUTEX_LOCKER macro to ease 342 debugging of deadlocks. 343 (MachThread::SetState): Ditto. 344 * MacOSX/MachVMMemory.cpp (MachVMMemory::Read): Improved logging. 345 (MachVMMemory::Write): Ditto. 346 (MachVMMemory::WriteRegion): Ditto. 347 * MacOSX/MachProcess.cpp (MachProcess::GetState): Use new 348 PTHREAD_MUTEX_LOCKER macro to ease debugging of deadlocks. 349 (MachProcess::SetState): Ditto. 350 (MachProcess::Clear): Ditto. 351 (MachProcess::PrivateResume): Ditto. 352 (MachProcess::ReplyToAllExceptions): Ditto. 353 (MachProcess::ExceptionMessageReceived): Ditto. 354 (MachProcess::AppendSTDOUT): Ditto. 355 (MachProcess::GetAvailableSTDOUT): Ditto. 356 (MachProcess::ThreadFunctionSTDIO): Renamed from to 357 MachProcess::STDIOThread. 358 (MachProcess::StartSTDIOThread): Improved logging. 359 (MachProcess::CreateBreakpoint): Ditto. 360 (MachProcess::CreateWatchpoint): Ditto. 361 (MachProcess::DisableAllBreakpoints): Ditto. 362 (MachProcess::DisableBreakpoint): Ditto. 363 (MachProcess::DisableWatchpoint): Ditto. 364 (MachProcess::EnableBreakpoint): Ditto. 365 (MachProcess::EnableWatchpoint): Ditto. 366 (MachProcess::LaunchForDebug): Ditto. 367 (MachProcess::PosixSpawnChildForPTraceDebugging): Ditto. 368 (MachProcess::Detach): Reset the running event bit after resuming prior 369 to issuing the SIGSTOP to avoid a pause. 370 (MachProcess::RemoveTrapsFromBuffer): New function that removes 371 breakpoint traps from a memory buffer. 372 (MachProcess::ReadMemory): Read memory from the task, then removes any 373 breakpoint traps prior to returning the buffer. 374 (MachProcess::WriteMemory): Write memory and any needed data to the 375 breakpoint saved opcodes for any software breakpoint traps that are 376 enabled. 377 * MacOSX/MachProcess.h (MachProcess::ThreadFunctionException): Removed. 378 (MachProcess::ThreadFunctionSTDIO): Renamed to MachProcess::STDIOThread(). 379 (MachProcess::RemoveTrapsFromBuffer): New function. 380 * MacOSX/MachVMRegion.cpp (MachVMRegion::SetProtections): Improved 381 logging. 382 (MachVMRegion::RestoreProtections): Ditto. 383 (MachVMRegion::GetRegionForAddress): Ditto. 384 * MacOSX/MachException.cpp (catch_mach_exception_raise_state): Improved 385 logging. 386 (catch_mach_exception_raise_state_identity): Ditto. 387 (catch_mach_exception_raise): Ditto. 388 (MachException::Message::Dump): Ditto. 389 (MachException::Data::GetStopInfo): Ditto. 390 (MachException::Message::Receive): Ditto. 391 (MachException::Message::Reply): Ditto. 392 (MachException::Data::Dump): Ditto. 393 (MachException::PortInfo::Save): Ditto. 394 (MachException::PortInfo::Restore): Ditto. 395 * MacOSX/MachTask.cpp (MachTask::Suspend): Improved logging. 396 (MachTask::Resume): Ditto. 397 (MachTask::ReadMemory): Ditto. 398 (MachTask::WriteMemory): Ditto. 399 (MachTask::TaskPortForProcessID): Ditto. 400 (MachTask::BasicInfo): Ditto. 401 (MachTask::StartExceptionThread): Ditto. 402 (MachTask::ShutDownExcecptionThread): Ditto and use pthread_cancel to 403 interrupt the exception thread. 404 (MachTask::ExceptionThread): Ditto and revert back to infinite timeout 405 as pthread_cancel will break us out of infinite mach_msg receive calls. 406 * MacOSX/MachThreadList.cpp (MachThreadList::UpdateThreadList): Improved 407 logging. 408 (MachThreadList::CurrentThread): Use new PTHREAD_MUTEX_LOCKER macro to 409 ease debugging of deadlocks. 410 * DNBTimer.h (DNBTimer::DNBTimer): Initialize the mutex with a recursive 411 pthread. 412 (DNBTimer::Reset): Use new PTHREAD_MUTEX_LOCKER macro to ease debugging 413 of deadlocks. 414 (DNBTimer::TotalMicroSeconds): Ditto. 415 (DNBTimer::GetTime): Ditto. 416 (DNBTimer::ElapsedMicroSeconds): Ditto. 417 (DNBTimer::GetTimeOfDay): New class function. 418 * DNBError.cpp (DNBError::LogThreaded): Improved logging. 419 * test-dbgnub.cpp 420 * PThreadMutex.h: Added the ability to debug deadlocks by defining 421 DEBUG_PTHREAD_MUTEX_DEADLOCKS. 422 * FunctionProfiler.cpp 423 * PThreadEvent.cpp (PThreadEvent::NewEventBit): Use new 424 PTHREAD_MUTEX_LOCKER macro to ease debugging of deadlocks. 425 (PThreadEvent::FreeEventBits): Ditto. 426 (PThreadEvent::GetEventBits): Ditto. 427 (PThreadEvent::ReplaceEventBits): Ditto. 428 (PThreadEvent::SetEvents): Ditto. 429 (PThreadEvent::ResetEvents): Ditto. 430 (PThreadEvent::WaitForSetEvents): Ditto. 431 (PThreadEvent::WaitForEventsToReset): Ditto. 432 4332008-12-05 Greg Clayton <gclayton@apple.com> 434 435 * DNBDefs.h (LOG_TASK): New log bit. 436 * DNB.cpp (DNBProcessIsAlive): User newly abtracted MachTask class. 437 (DNBProcessMemoryRead): Ditto. 438 (DNBProcessMemoryWrite): Ditto. 439 * DNBArchImpl.cpp (DNBArchMachARM::EnableHardwareSingleStep): Ditto. 440 (DNBArchMachARM::SetSingleStepSoftwareBreakpoints) Ditto. 441 * MachException.cpp (MachException::Message::Receive): Cleaned up logging 442 so it doesn't always log timeout errors. 443 (MachException::Message::Reply): Use abstracted MachTask class for any 444 task related queries. 445 (MachException::PortInfo::Save): Cleaned up logging. 446 (MachException::PortInfo::Restore): Cleaned up logging and now return an 447 error instead of the number of restored port infos. 448 * MachProcess.cpp (class MachProcess): Abstracted out all of the task_t 449 related stuff (suspend, resuyme, exception ports, exception thread, and 450 more) into a new class MachTask. 451 (MachProcess::Task): Now returns a reference to a MachTask class. 452 (MachProcess::Clear): Uses new abstracted MachTask class. 453 (MachProcess::Detach): Ditto. 454 (MachProcess::PrivateResume): Ditto. 455 (MachProcess::DisableBreakpoint): Ditto. 456 (MachProcess::ExceptionMessageReceived): Ditto. 457 (MachProcess::ExceptionMessageBundleComplete): Ditto. 458 (MachProcess::AttachForDebug): Ditto. 459 (MachProcess::LaunchForDebug): Ditto. 460 (MachProcess::SBLaunchForDebug): Ditto. 461 (MachProcess::TaskIsValid): Removed (replaced by similar functionality 462 in the new MachTask class). 463 (MachProcess::ExceptionPort): Ditto. 464 (MachProcess::ExceptionPortIsValid): Ditto. 465 (MachProcess::StartExceptionThread): Ditto. 466 (MachProcess::Suspend): Ditto. 467 (MachProcess::TaskResume): Ditto. 468 (MachProcess::TaskBasicInfo): Ditto. 469 (MachProcess::TaskBasicInfo): Ditto. 470 (MachProcess::ReadMemory): Ditto. 471 (MachProcess::WriteMemory): Ditto. 472 (MachProcess::ThreadFunctionException): Ditto. 473 4742008-12-04 Greg Clayton <gclayton@apple.com> 475 476 * DNB.h (DNBProcessSetEvents): New API function prototype. 477 * DNB.cpp (DNBProcessSetEvents): New API function. 478 (DNBProcessHalt): Send our process a SIGINT instead of suspending 479 the task. 480 * DNBDefs.h (NUB_STATE_IS_STOPPED): Removed up duplicate entry in macro. 481 (eEventPrcoessAsyncInterrupt): New prcoess event bit that allows async 482 interrupting of infinite DNBProcessWaitForEvent() function calls. 483 * MachException.cpp (MachException::Message::Receive): Improved logging. 484 (MachException::Message::Reply): Improved logging. 485 * MachProcess.h (MachProcess::TaskBasicInfo): New member and static 486 functions. 487 * MachProcess.cpp (MachProcess::TaskIsValid): Use new TaskBasicInfo() 488 member function. 489 (MachProcess::Resume): Removed the detach parameter from the PrivateResume() 490 function call. 491 (MachProcess::Kill): Added a absolute timeout pointer to allow callers to 492 wait for the signal to be received if the timeout is non-NULL. 493 (MachProcess::TaskBasicInfo): New member and static function. 494 (MachProcess::TaskResume): New function that resumes the task by making sure 495 the suspend count is correctly ref counted. 496 (MachProcess::Detach): When detaching from a process make sure it is 497 stopped (SIGSTOP) first, then we can successfully detach. The exception 498 thread now also properly exits. 499 (MachProcess::PrivateResume): Call new TaskResume function, and removed the 500 detach functionality. 501 (MachProcess::DisableBreakpoint): Only notify the thread list that a 502 breakpoint has changed if the breakpoint is going to be removed. 503 (MachProcess::ThreadFunctionException): Added a permanent 1 second timeout 504 for each call to mach_msg() so we can exit the thread in the event that 505 we detach from a process/task. 506 * test-debugnub (main): Modified to show an example of how to detach using 507 a signal_handler to asynchronously receive a SIGINT and properly interrupt 508 and detach from a running process. 509 5102008-11-26 Greg Clayton <gclayton@apple.com> 511 512 * DNBDefs.h (LOG_STEP): New logging define. 513 * DNBError.cpp (DNBError::LogThreaded): If there is no error, then 514 log with "success: " as a prefix instead of "error: ". 515 * arm/DBNArchImpl.cpp (DNBArchMachARM::EnableHardwareSingleStep): Log using 516 new LOG_STEP instead of LOG_BREAKPOINTS. 517 (DNBArchMachARM::SetSingleStepSoftwareBreakpoints): Ditto. 518 * MachException.cpp (MachException::Message::Dump): Log excetion header 519 and reply header on two separate lines. 520 * MachProcess.cpp (IsSBProcess): Check for NULL CFArrayRef returned from 521 SBSCopyApplicationDisplayIdentifiers for SkankPhone. 522 (MachProcess::Suspend): Check if process state is not running instead of 523 having to receive an event after a timeout if one is given. 524 (MachProcess::Detach): Deallocate the exception port when detaching and 525 restore the inferior task exception ports prior to clearing and detaching. 526 (MachProcess::PrivateResume): Grab the task's basic info and make sure we 527 get the resume the correct number of times. 528 (MachProcess::DisableBreakpoint): Removed unused variable opcode_restored 529 and make sure the breakpoint is enabled before we start warning that 530 our opcode wasn't there. 531 * ppc/DBNArchImpl.cpp (DNBArchMachPPC::EnableHardwareSingleStep): Log 532 using LOG_STEP instead of LOAD_BREAKPOINTS. 533 * RNBServices.cpp (IsSBProcess): Check for NULL CFArrayRef returned from 534 SBSCopyApplicationDisplayIdentifiers for SkankPhone. 535 5362008-11-26 Greg Clayton <gclayton@apple.com> 537 538 * MachProcess.h (MachProcess::Suspend): Now takes an optional absolute 539 timeout that, if non-NULL, will case the function to return after the 540 process has been suspended and is in a stopped state. If the timeout is 541 NULL, then no waiting will occur. 542 * MachProcess.cpp (MachProcess::Suspend): Ditto. 543 (MachProcess::Detach): Now replies to all exceptions, un-suspends all 544 threads and resumes the task. 545 (MachProcess::ReplyToAllExceptions): New function. 546 (MachProcess::PrivateResume): Now takes an additional parameter named 547 detach that will do the right thing when detaching from a process. 548 * DNBArchImpl.h (DNBArchMachI386::ThreadWillResume): Returns void. 549 * DNBArchImpl.cpp (DNBArchMachI386::ThreadWillResume): Returns void. 550 * RNBServices.cpp (ListApplications): #ifdef-ed for ARM only as it 551 currently uses SpringBoard. 552 (IsSBProcess): Ditto. 553 * test-remotenub.cpp (RNBRunLoopLaunchInferior): #ifdef-ed around 554 ARM parts so it compiles for i386. 555 (main): Ditto. 556 5572008-11-24 Greg Clayton <gclayton@apple.com> 558 559 * DNBArchProtocol.h (DNBArchProtocol::ThreadWillResume): Now returns void. 560 * DNBArchImpl.cpp (DNBArchMachARM::ThreadWillResume): Returns void and 561 has hollowed out support for software single step. 562 (DNBArchMachARM::ThreadDidStop): Has a debug mode that uses hardware single 563 step to verify software single step that can be enabled by defining 564 DNB_ARCH_MACH_ARM_DEBUG_SW_STEP. 565 (DNBArchMachARM::SetSingleStepSoftwareBreakpoints): New function. 566 * DNBArchImpl.h (DNBArchMachARM::ThreadWillResume): Returns void. 567 (DNBArchMachARM::SetSingleStepSoftwareBreakpoints): New prototype. 568 (DNBArchMachARM::m_sw_single_step_next_pc): New member variable. 569 (DNBArchMachARM::m_sw_single_step_break_id): New member variable. 570 * MachThread.cpp (MachThread::ThreadWillResume): Now returns void. 571 * MachThread.h (MachThread::ThreadWillResume): Now returns void. 572 5732008-11-19 Greg Clayton <gclayton@apple.com> 574 575 * DNBError.h (FlavorType): Added SpringBoard error type for arm builds. 576 * DNBError.cpp (DNBError::AsString): Now returns SpringBoard error strings 577 if the error type is SpringBoard. 578 * test-remotenub.cpp (RNBRunLoopLaunchInferior): Set the error into 579 RNBContext as either a POSIX error or a SpringBoard error. 580 * RNBContext.h (m_launch_status): Changed this member to be a DNBError 581 instead of a uint32_t. 582 (RNBContext::LaunchStatus): Now returns a reference to the DNBError object 583 in m_launch_status. 584 * RNBContext.cpp (RNBContext::LaunchStatusAsString): Let DNBError handle 585 any error string descriptions, including SpringBoard errors. 586 * RNBRemote.cpp (RNBRemote::HandlePacket_q): Use new error class in 587 RNBContext. 588 (RNBRemote::HandlePacket_C): Return without an erroneous error when resuming 589 a process with a signal. 590 * DNBArch.h (DNBArchProtocol::StepNotComplete): New protocol function with 591 default return value. 592 * DNBArchImpl.cpp (DNBArchMachARM::StepNotComplete): New function. 593 (DNBArchMachARM::EnableHardwareSingleStep): Handle hardware single stepping 594 over 32 bit thumb instructions better so we always do a true instruction 595 level single step. 596 * MachProcess.cpp (MachProcess::ExceptionMessageBundleComplete): Now resumes 597 if single stepping wasn't able to complete in a single run. 598 * MachThread.cpp (MachThread::ShouldStop): Fills in new step_more parameter 599 if stepping is not complete. 600 * MachThreadList.cpp (MachThreadList::ShouldStop): Pass step_more parameter 601 to each MachThread::ShouldStop call. 602 6032008-11-13 Greg Clayton <gclayton@apple.com> 604 605 * MachProcess.cpp (MachProcess::PosixSpawnChildForPTraceDebugging): Don't 606 call posix_spawnattr_setbinpref_np when launching with posix_spawn on ARM 607 targets as it currently selects the incorrect slice due to multiple slices 608 that contain the same cputype, yet they all have differing cpusubtypes. 609 6102008-11-04 Greg Clayton <gclayton@apple.com> 611 612 * RNBRemote.h (GetContinueThread): Don't return the current thread when 613 the continue thread is zero or -1. 614 * RNBRemote.cpp (RNBRemote::HandlePacket_c): Resume the process if we 615 have no continue thread set. 616 (RNBRemote::HandlePacket_s): Ditto. 617 (RNBRemote::HandlePacket_C): Ditto unless a continue address is specified 618 in which case we will only succeed if we have one thread when the continue 619 with signal and address doesn't have a continue thread specified. 620 (RNBRemote::HandlePacket_S): Ditto. 621 * DNB.cpp (DNBProcessResumeWithSignal): New function. 622 (DNBProcessResume): Added better logging. 623 (DNBProcessHalt): Ditto. 624 (DNBThreadResume): Ditto. 625 (DNBThreadResumeWithSignal): Ditto. 626 * DNB.h (DNBProcessResumeWithSignal): New prototype. 627 * DNBError.cpp (DNBError::LogThreaded): New function. 628 * DNBError.h (DNBError::LogThreaded): New prototype. 629 * DNBLog.cpp (_DNBLogThreaded): Added sequence ID for threaded logs. 630 (_DNBLogThreadedIf): Ditto. 631 * MachException.cpp (MachException::Data::GetStopInfo): Use new SoftSignal() 632 accessor. 633 (MachException::Data::DumpStopReason): Ditto. 634 (MachException::Message::Reply): Added better logging and log using the 635 soft signal if our task matches that in the exception. 636 (MachException::Data::Dump): Added better logging. 637 * MachException.h (IsSoftSignal): Removed. 638 (SoftSignal): New function that returns the soft signal in the exception 639 data if there is one, or zero otherwise. 640 * MachProcess.cpp (MachProcess::Suspend): Improved logging. 641 (MachProcess::Resume): Ditto. 642 (MachProcess::PrivateResume): Handle the case where the process is told 643 to resume with a signal by matching the signal up to the thread that had 644 the soft signal if no thread id is specified. 645 * MachThread.cpp (MachThread::Suspend): Improved logging. 646 (MachThread::Resume): Improved logging. 647 (MachThread::RestoreSuspendCount): Improved logging. 648 (MachThread::Resume): Improved logging. 649 (MachThread::Dump): Improved logging. 650 * MachThreadList.cpp (MachThreadList::Dump): Improved logging. 651 6522008-10-22 Greg Clayton <gclayton@apple.com> 653 654 * test-remotenub.cpp (RNBRunLoopMode): Added a new enum value 655 eRNBRunLoopModeInferiorAttaching. 656 (g_long_options): Added "--attach=PID" for attaching to existing processes 657 and "--launch=(auto|posix|fork|springboard)" options. 658 (RNBRunLoopLaunchInferior): Now launches process with new 659 nub_launch_flavor_t enum that can be overridden with the --launch option. 660 (RNBRunLoopLaunchAttaching): New function for attaching to existing 661 processes. 662 (main): Added command line option support for the "--attach" and "--launch" 663 options and added attach to pid support and better logging. 664 * DNB.cpp/h: (DNBProcessLaunch): Added nub_launch_flavor_t and error 665 parameter for more precise control when launching processes. 666 (DNBProcessSBLaunch): Removed function as launching with SpringBoard can 667 now be done using DNBProcessLaunch with launch_flavor being set to 668 eLaunchTypeSpringBoard (arm only). 669 (DNBProcessSBAttach): Removed function (SpringBoard processes are now auto 670 detected in the MachProcess::AttachForDebug function on ARM). 671 * DNBDefs.h (NUB_GENERIC_ERROR): New generic error definition. 672 (nub_launch_flavor_t): New enumeration used for control over process 673 launching. 674 * MachProcess.cpp (IsSBProcess): New function. 675 (MachProcess::AttachForDebug): Removed flags parameter that was being used 676 for SpringBoard flags and we now detect if a process belongs to SpringBoard 677 by calling IsSBProcess. 678 (MachProcess::LaunchForDebug): Now has launch parameter that tells it how 679 to launch the inferior process and there is also an error code that gets 680 returned. This function can now launch using fork + exec, posix_spawn, 681 or SpringBoard on ARM targets. 682 (MachProcess::SBLaunchForDebug): Now uses DNBError reference instead of 683 uint32_t pointer for the error code. 684 (MachProcess::SBForkChildForPTraceDebugging): Ditto. 685 6862008-10-22 Greg Clayton <gclayton@apple.com> 687 688 * MacOSX/arm/DNBArchImpl.cpp (DNBArchMachARM::GetRegisterValue): Set 689 register value to a uint32 value instead of a float64 value for s0 - 690 s31. 691 6922008-10-17 Greg Clayton <gclayton@apple.com> 693 694 * test-remotenub.cpp (RNBRunLoopLaunchInferior): Don't listen for 695 the qLaunchSuccess if we aren't doing a lockdown connnection. 696 6972008-10-13 Greg Clayton <gclayton@apple.com> 698 699 * RNBRemote.h (class RNBRemote): Added m_watchpoints member. 700 * DNB.cpp (DNBBreakpointSet): Added boolean hardware parameter for 701 requesting that a hardware breakpoint be set. 702 (DNBWatchpointSet): New function. 703 (DNBWatchpointClear): New function. 704 (DNBWatchpointGetHitCount): New function. 705 (DNBWatchpointGetIgnoreCount): New function. 706 (DNBWatchpointSetIgnoreCount): New function. 707 (DNBWatchpointSetCallback): New function. 708 (DNBWatchpointPrint): New function. 709 * DNBRegisterInfo.cpp (DNBRegisterValueClass::Dump): Modified to emit 710 a single DNBLog() call so there aren't multiple newlines when logging 711 to ASL. 712 * RNBContext.cpp (RNBContext::ThreadFunctionProcessStatus): Use new 713 process state changed events. 714 * DNBBreakpoint.h (class DNBBreakpoint): Removed m_state member and 715 added m_tid, m_enabled, m_hw_preferred, m_is_watchpoint, m_watch_read, 716 m_watch_write, and m_hw_index. 717 (DNBBreakpoint::ThreadID()): New accessor. 718 (DNBBreakpoint::IsEnabled()): New accessor. 719 (DNBBreakpoint::SetEnabled()): New accessor. 720 (DNBBreakpoint::IsWatchpoint()): New accessor. 721 (DNBBreakpoint::IsBreakpoint()): New accessor. 722 (DNBBreakpoint::SetIsWatchpoint()): New accessor. 723 (DNBBreakpoint::WatchpointRead()): New accessor. 724 (DNBBreakpoint::WatchpointWrite()): New accessor. 725 (DNBBreakpoint::HardwarePreferred()): New accessor. 726 (DNBBreakpoint::IsHardware()): New accessor. 727 (DNBBreakpoint::GetHardwareIndex()): New accessor. 728 (DNBBreakpoint::SetHardwareIndex()): New accessor. 729 (DNBBreakpoint::ThreadID()): New accessor. 730 (DNBBreakpoint::GetState()): Removed accessor. 731 (DNBBreakpoint::SetState()): Removed accessor. 732 (DNBBreakpoint::AddBreakpoint()): Renamed to Add(). 733 (DNBBreakpoint::RemoveBreakpoint()): Renamed to Remove(). 734 (DNBBreakpoint::FindBreakIDForAddress()): Renamed to FindIDByAddress(). 735 (DNBBreakpoint::ShouldStopAtBreakpoint()): Renamed to ShouldStop(). 736 (DNBBreakpoint::SetBreakpointCallback()): Renamed to SetCallback(). 737 (DNBBreakpoint::FindBreakpointWithAddress()): Renamed to 738 FindByAddress(). 739 (DNBBreakpoint::FindBreakpointWithBreakID()): Renamed to FindByID(). 740 (DNBBreakpoint::GetBreakpointAtIndex()): Renamed to GetByIndex(). 741 * FunctionProfiler.h: New header for subclass of DNBRuntimeAction. 742 * RNBRemote.cpp (RNBRemote::HandlePacket_v): Use new process state 743 changed events. 744 (RNBRemote::HandlePacket_z): Implement the hardware breakpoint and 745 watchpoint commands z1, Z1, z2, Z2, z3 and Z3 746 * PThreadEvent.h (PThreadEvent::GetEventBits): Made member function 747 const. 748 (PThreadEvent::WaitForSetEvents): Ditto. 749 (PThreadEvent::WaitForEventsToReset): Ditto. 750 (PThreadEvent::WaitForResetAck): Ditto. 751 (PThreadEvent::m_mutex): Made class member mutable. 752 (PThreadEvent::m_set_condition): Made class member mutable. 753 (PThreadEvent::m_reset_condition): New mutable class member. 754 * ProfileObjectiveC.cpp 755 * DNBArch.h (DNBArch::NotifyException): Now has default implementation 756 that returns false. 757 (DNBArch::NumSupportedHardwareBreakpoints): New virtual member 758 function with a default implementation. 759 (DNBArch::NumSupportedHardwareWatchpoints): Ditto. 760 (DNBArch::EnableHardwareBreakpoint): Ditto. 761 (DNBArch::EnableHardwareWatchpoint): Ditto. 762 (DNBArch::DisableHardwareBreakpoint): Ditto. 763 (DNBArch::DisableHardwareWatchpoint): Ditto. 764 * DNB.h (DNBBreakpointSet): New take a HARDWARE parameter that allows 765 requests for setting hardware breakpoints. 766 (DNBWatchpointSet): New function prototype. 767 (DNBWatchpointClear): New function prototype. 768 (DNBWatchpointGetHitCount): New function prototype. 769 (DNBWatchpointGetIgnoreCount): New function prototype. 770 (DNBWatchpointSetIgnoreCount): New function prototype. 771 (DNBWatchpointSetCallback): New function prototype. 772 (DNBWatchpointPrint): New function prototype. 773 * MacOSX/arm/DNBArchImpl.cpp: Added hardware breakpoint and watchpoint 774 support for ARM. 775 (DNBArchMachARM::GetCPUType): New function. 776 (DNBArchMachARM::DumpDBGState): New function. 777 (DNBArchMachARM::GetDBGState): New function. 778 (DNBArchMachARM::SetDBGState): New function. 779 (DNBArchMachARM::EnableHardwareSingleStep): New function. 780 (DNBArchMachARM::EnableHardwareBreakpoint): New function. 781 (DNBArchMachARM::NotifyException): Removed. 782 (DNBArchMachARM::DisableHardwareBreakpoint): New function. 783 (DNBArchMachARM::EnableHardwareWatchpoint): New function. 784 (DNBArchMachARM::DisableHardwareWatchpoint): New function. 785 * MacOSX/MachThread.cpp (MachThread::Suspend): Added better logging. 786 (MachThread::Resume): Ditto. 787 (MachThread::RestoreSuspendCount): Ditto. 788 (MachThread::Dump): Ditto. 789 (MachThread::EnableHardwareBreakpoint): New function. 790 (MachThread::EnableHardwareWatchpoint): New function. 791 (MachThread::DisableHardwareBreakpoint): New function. 792 (MachThread::DisableHardwareWatchpoint): New function. 793 * MacOSX/MachThreadList.h (MachThreadList::GetLastError): Removed. 794 (MachThread::EnableHardwareBreakpoint): New prototype. 795 (MachThread::DisableHardwareBreakpoint): New prototype. 796 (MachThread::EnableHardwareWatchpoint): New prototype. 797 (MachThread::DisableHardwareWatchpoint): New prototype. 798 (class MachThread): Remove m_err member variable. 799 * MacOSX/ppc/DNBArchImpl.cpp (DNBArchMachPPC::GetCPUType) New 800 function. 801 (DNBArchMachPPC::NotifyException): Removed. 802 * MacOSX/ppc/DNBArchImpl.h (DNBArchMachPPC::NotifyException): Removed. 803 * MacOSX/MachThread.h (MachThread::EnableHardwareBreakpoint): New 804 prototype. 805 (MachThread::EnableHardwareWatchpoint): New prototype. 806 (MachThread::DisableHardwareBreakpoint): New prototype. 807 (MachThread::DisableHardwareWatchpoint): New prototype. 808 (class MachThread): Renambed class member m_exception to 809 m_stop_exception. 810 * MacOSX/MachProcess.cpp (MachProcess::SetState): Updated to use new 811 process event enumerations. 812 (MachProcess::PrivateResume): Added better logging. 813 (MachProcess::CreateBreakpoint): Added bool HARDWARE parameter for 814 requesting hardware breakpoints. 815 (MachProcess::CreateWatchpoint): New function. 816 (MachProcess::DisableAllWatchpoints): New function. 817 (MachProcess::DisableWatchpoint): New function. 818 (MachProcess::DumpWatchpoint): New function. 819 (MachProcess::EnableBreakpoint): Enabled breakpoints in hardware if 820 requested and supported. 821 (MachProcess::DisableBreakpoint): Disable hardware breakpoints if that 822 is how they were set. 823 (MachProcess::EnableWatchpoint): New function. 824 (MachProcess::ExceptionMessageBundleComplete): Wait for the 825 eEventProcessRunningStateChanged event to be reset before changing 826 state to stopped to avoid race condition with very fast start/stops. 827 (MachProcess::LaunchForDebug): Added posix_spawn support. 828 (MachProcess::PosixSpawnChildForPTraceDebugging): New function. 829 * MacOSX/i386/DNBArchImpl.cpp (DNBArchMachI386::GetCPUType): New 830 function. 831 * MacOSX/i386/DNBArchImpl.h (DNBArchMachI386::GetCPUType): New 832 prototype. 833 * MacOSX/MachProcess.h (PosixSpawnChildForPTraceDebugging): New 834 prototype. 835 * MacOSX/MachException.cpp (class MachException::ThreadMessage): 836 Renamed class to MachException::Data. 837 * MacOSX/MachThreadList.cpp (class MachThreadList): Removed m_err 838 class member. 839 (MachThreadList::EnableHardwareBreakpoint): New function. 840 (MachThreadList::DisableHardwareBreakpoint): New function. 841 (MachThreadList::EnableHardwareWatchpoint): New function. 842 (MachThreadList::DisableHardwareWatchpoint): New function. 843 * MacOSX/MachException.h (class MachException::ThreadMessage): 844 Renamed class to MachException::Data. 845 * DNBDefs.h (nub_watch_t): New typedef. 846 (INVALID_NUB_HW_INDEX): New macro definition. 847 (WATCH_TYPE_READ): New macro definition. 848 (WATCH_TYPE_WRITE): New macro definition. 849 (NUB_STATE_IS_RUNNING): New macro to see if state is a running state. 850 (NUB_STATE_IS_STOPPED): New macro to see if state is a stopped state. 851 (eEventProcessStateChanged): Deprecated. 852 (eEventProcessRunningStateChanged): New process event state. 853 (eEventProcessStoppedStateChanged): New process event state. 854 (LOG_WATCHPOINTS): New macro definition for logging watchpoints. 855 * test-remotenub.cpp (RNBRunLoopLaunchInferior): Use new process 856 event states. 857 * FunctionProfiler.cpp: New class that allows single stepping through 858 an address range for tracing exact call graphs. 859 8602008-09-22 Greg Clayton <gclayton@apple.com> 861 862 * RNBRemote.h (GetContinueThread): If the continue thread is zero or 863 -1 then return GetCurrentThread(). 864 * RNBRemote.cpp (m_packets): Made the vCont functions call 865 RNBRemote::HandlePacket_v(). 866 (RNBRemote::HandlePacket_H): Cleaned up whitespace. 867 (RNBRemote::HandlePacket_last_signal): Return actual signal values for 868 EXE_SOFTWARE/EXC_SOFT_SIGNAL mach exceptions. 869 (RNBRemote::HandlePacket_v): Implemented the 'vCont?' and 'vCont;' 870 packets. 871 (RNBRemote::HandlePacket_c): Handle the case where an address is 872 provided. 873 (RNBRemote::HandlePacket_C): Implemented the continue with signal 874 including when an address is provided. 875 (RNBRemote::HandlePacket_S): Implemented the step with signal 876 including when an address is provided. 877 * DNB.cpp (DNBProcessResume): Pass 0 as the signal when resuming 878 a process without specifying a thread. 879 (DNBThreadResume): Pass 0 as the signal when resuming a specific thread. 880 (DNBThreadResumeWithSignal): New function. 881 * DNB.h (DNBThreadResumeWithSignal): New prototype. 882 * MachException.h (MachException::Message::Reply): Added a signal 883 parameter. 884 * MachException.cpp (MachException::Message::Reply): Update the thread 885 with the new SIGNAL parameter instead of always zero so signals can be 886 passed on to programs. 887 * MachProcess.h (MachProcess::Resume): Added a signal parameter. 888 * MachProcess.h (MachProcess::PrivateResume): Added a signal parameter. 889 * MachProcess.cpp (MachProcess::Resume): Pass new SIGNAL parameter to 890 MachProcess::PrivateResume. 891 * MachProcess.cpp (MachProcess::PrivateResume): Pass new SIGNAL 892 parameter to the mach exception reply. 893 8942008-08-08 Greg Clayton <gclayton@apple.com> 895 896 * DNB.cpp (gProcessMap): Removed static C++ global. 897 (GetProcessMap): New Function. 898 (AddProcessToMap): New function. 899 (RemoveProcessFromMap): New function. 900 (GetProcessSP): Use new GetProcessMap function to get process list. 901 9022008-07-30 Greg Clayton <gclayton@apple.com> 903 904 * debugserver-entitlements.plist (get-task-allow): Removed. 905 (run-invalid-allow): Added boolean value set to TRUE. 906 9072008-04-18 Greg Clayton <gclayton@apple.com> 908 909 * MachProcess.cpp (MachProcess::Task): Added getuid(), geteuid(), 910 getgid(), getegid() to the log message if task for pid fails. 911 9122008-04-07 Greg Clayton <gclayton@apple.com> 913 914 * RNBContext.cpp (RNBContext::LaunchStatusAsString): Removed unused 915 tmp_str variable. 916 9172008-04-04 Greg Clayton <gclayton@apple.com> 918 919 * CFString.cpp/h (UTF8): Made a static function that can convert 920 a CFStringRef to UTF8. 921 9222008-04-04 Greg Clayton <gclayton@apple.com> 923 924 * test-remotenub.cpp (main): Make sure we exit after we send the 925 application list. 926 9272008-04-04 Greg Clayton <gclayton@apple.com> 928 929 * RNBServices.h (IsSBProcess): New prototype; 930 * RNBServices.cpp (IsSBProcess): New function that returns true it 931 SpringBoard owns or knows about the process. 932 * RNBRemote.cpp (RNBRemote::HandlePacket_v): Made attach work correctly. 933 * DNB.cpp (DNBProcessSBAttach): New function for use when attaching to 934 a process owned by SpringBoard. 935 (DNBProcessAttach): Fixed an issue where a local was shadowing a 936 parameter. 937 * DNB.h (DNBProcessSBAttach): New prototype. 938 * MachProcess.cpp (MachProcess::AttachForDebug): AttachForDebug now 939 takes some flags so it knows to enable SpringBoard functionality. 940 * MachProcess.h (MachProcess::AttachForDebug): Added flags parameter 941 to prototype. 942 9432008-04-04 Greg Clayton <gclayton@apple.com> 944 945 * test-remotenub.cpp (RNBRunLoopGetArgsFromRemote): Handle the new 946 attach packet and watch for connection being lost. 947 (main): handle the --applist option when there we aren't using lockdown 948 by printing the results to stdout and exiting with appropriate error code 949 if we failed. Also handle the new prototype for ListApplications. 950 * RNBServices.h (ListApplications): Change first parameter to be a std::string 951 that will get the contents of the plist so we can use this for more than 952 just lockdown. 953 * RNBServices.cpp (ListApplications): Change first parameter to be a std::string 954 that will get the contents of the plist so we can use this for more than 955 just lockdown and also fixed the logic so we actually create a full list of 956 applications instead of just overwriting the first entry. 957 * RNBRemote.h (PacketEnum): Added a new 'vattach' enum for the "vAttach;PID" 958 gdb remote command. 959 (RNBRemote::HandlePacket_v): New prototype; 960 * RNBRemote.cpp (RNBRemote::CreatePacketTable): add the vattach packet definition 961 to m_packets. 962 (RNBRemote::HandlePacket_v): New function that handles attach to a process. 963 9642008-04-03 Jim Ingham <jingham@apple.com> 965 966 * RNBRemote.h: Add query_launch_success to packet enum. 967 * RNBRemote.cpp (RNBRemote::CreatePacketTable_): Add query_launch_success. 968 (HandlePacket_q): Handle query_launch_success. 969 * DNB.cpp (DNBProcessSBLaunch): Pass in launch_retval. 970 * DNB.h: Change prototype of DNBProcessSBLaunch to take launch_retval. 971 * RNBContext.cpp (RNBContext::LaunchStatusAsString): New function. 972 * RNBContext.h (RNBContext): Add m_launch_status & accessors. 973 * macosx/MachProcess.cpp (MachProcess::SBLaunchForDebug): Pass launch_retval. 974 (MachProcess::SBForkChildForPTraceDebugging): Accept & set launch_retval. 975 * Macosx/MachProcess.h: Change prototypes of SBLaunchForDebug & 976 ForkChildForPTraceDebugging to accept launch_retval. 977 * test-remotenub.cpp (RNBRunLoopLaunchInferior): Get the launch status and 978 put it in the context, then wait for the qLaunchStatus packet. 979 9802008-04-03 Greg Clayton <gclayton@apple.com> 981 982 * com.apple.debugserver.plist: Changed plist so debugserver 983 runs as mobile user. 984 * com.apple.debugserver.applist.plist: Ditto. 985 9862008-04-03 Greg Clayton <gclayton@apple.com> 987 988 * MachProcess.cpp: (MachProcess::SBForkChildForPTraceDebugging): 989 Increased SBS application launch timeout to 30 seconds. 990 9912008-03-27 Christopher Friesen <friesen@apple.com> 992 993 * RNBServices.h: Pass tasks from SpringBoard as a plist 994 * RNBServices.cpp: Ditto. 995 * test-remotenub.cpp: added --applist flag 996 * com.apple.debugserver.applist.plist: Agent plist 997 9982008-03-17 Jim Ingham <jingham@apple.com> 999 1000 * DNB.h: Pass envp to DNBProcessLaunch & DNBProcessSBLaunch. 1001 * DNB.cpp: Ditto. 1002 * MachProcess.h: Ditto for *LaunchForDebug and 1003 *ForkChildForPtraceDebugging. 1004 * MachProcess.cpp (MachProcess::LaunchForDebug): Pass on envp. 1005 (MachProcess::SBLaunchForDebug): Ditto. 1006 (MachProcess::ForkChildForPtraceDebugging): Accept envp, haven't actually 1007 implemented the passing yet. 1008 (MachProcess::SBForkChildForPtraceDebuggin): Accept envp, convert to 1009 CFDictionary and pass to SBSLaunchApplication. 1010 * RNBContext.h: Add environment to the context. 1011 * RBNContext.cpp (RNBContext::EnvironmentAtIndex): New function. 1012 * RNBRemote.h: Add set_environment_variable to the PacketEnum. 1013 * RNBRemote.cpp (RNBRemote::CreatePacketTable): Add QEnvironment:. 1014 * (RNBRemote::HandlePacket_Q): Ingest the environment variable. 1015 * test-remotenub.cpp (RNBRunLoppLaunchInferior): Convert the env 1016 array in the context into an array, and pass it to the DNBProcess*Launch 1017 methods. 1018 10192008-03-17 Greg Clayton <gclayton@apple.com> 1020 1021 * DNBBreakpoint.cpp (DNBBreakpointList::GetBreakpointAtIndex): New 1022 functions (const and non-const versions). 1023 * DNBBreakpoint.h (DNBBreakpointList::GetBreakpointAtIndex): New 1024 prototypes (const and non-const versions). 1025 * DNBError.h (DNBError::Success()): Don't use KERN_SUCCESS define. 1026 (DNBError::Fail()): Don't use KERN_SUCCESS define. 1027 * MachProcess.cpp (MachProcess::DisableAllBreakpoints): New function. 1028 (MachProcess::Detach): Added initial implementation that will halt 1029 the process, disable all breakpoints and call PT_DETACH. 1030 * MachProcess.h (MachProcess::DisableAllBreakpoints): New prototype. 1031 10322008-03-04 Greg Clayton <gclayton@apple.com> 1033 1034 * RNBRemote.h (RNBRemote::SendHexEncodedBytePacket): New prototype. 1035 * RNBRemote.cpp (RNBRemote::SendHexEncodedBytePacket): New function. 1036 (RNBRemote::SendSTDOUTPacket): Use SendHexEncodedBytePacket function 1037 to send bytes. 1038 (RNBRemote::SendSTDERRPacket): Ditto. 1039 (RNBRemote::HandlePacket_q): Return a valid thread info string for 1040 qThreadExtraInfo queries. 1041 * DNB.cpp (DNBThreadPrintStopReason): Commented out unused function. 1042 (DNBThreadGetInfo): New function. 1043 * DNB.h (DNBThreadPrintStopReason): Commented out prototype. 1044 (DNBThreadGetInfo): New prototype. 1045 * MachProcess.cpp (MachProcess::GetThreadInfo): New function. 1046 * MachProcess.h (MachProcess::GetThreadInfo): New prototype. 1047 * MachThreadList.cpp (MachThreadList::GetThreadInfo): New function. 1048 * MachThreadList.h (MachThreadList::GetThreadInfo): New prototype. 1049 * MachThread.cpp (MachThread::GetBasicInfoAsString): New function. 1050 (MachThread::InferiorThreadID): New function. 1051 * MachThread.cpp (MachThread::GetBasicInfoAsString): New prototype. 1052 (MachThread::InferiorThreadID): New prototype. 1053 10542008-02-27 Greg Clayton <gclayton@apple.com> 1055 1056 * RNBRemote.cpp (RNBRemote::HandlePacket_last_signal): Set the 1057 current thread when we notify a thread has stopped to subsequent 1058 g and p packets get the correct data. 1059 10602008-02-26 Jason Molenda (jmolenda@apple.com) 1061 1062 * RNBRemote.h: Add query_thread_extra_info enum. 1063 * RNBRemote.cpp: Add support for qThreadExtraInfo. 1064 Currently we return 'Ok' as the packet status for 1065 every thread. 1066 10672008-02-26 Jason Molenda (jmolenda@apple.com) 1068 1069 * RNBRemote.cpp (RNBRemote::HandlePacket_q): Correct handling 1070 of qfThreadInfo/qsThreadInfo. 1071 10722008-02-20 Jason Molenda (jmolenda@apple.com) 1073 1074 * RNBRemote.h: Change default for gdb's max incoming packet size to 1075 reflect the real default size. 1076 * RNBRemote.cpp (HandlePacket_Q): Correct the string comparisions for 1077 the QSetMaxPayloadSize and QSetMaxPacketSize packets. 1078 10792008-02-19 Christopher Friesen <friesen@apple.com> 1080 1081 * CFDataFormatters.c: CoreFoundation data formatters added to project. 1082 10832008-02-19 Jason Molenda (jmolenda@apple.com) 1084 1085 * RNBRemote.h: Record the max payload size, not the max packet 1086 size for less ambiguous meaning. 1087 * RNBRemote.cpp: Add support for QSetMaxPayloadSize: packet which 1088 should have a clearer meaning than QSetMaxPacketSize. 1089 QSetMaxPacketSize will be removed once we get have a chance to get 1090 a new debugserver and gdb submitted. 1091 10922008-02-18 Jason Molenda (jmolenda@apple.com) 1093 1094 * RNBRemote.h: Make default size 1024. 1095 * RNBRemote.cpp: Questionmark packet should stay under 1096 max_packet_size - 5 to allow for start, end, checksum and nul 1097 char bytes. 1098 10992008-02-18 Jason Molenda (jmolenda@apple.com) 1100 1101 * RNBRemote.h: Add m_max_packet_size to class defn. 1102 * RNBRemote.cpp: Initialize it, use it. 1103 11042008-02-18 Jason Molenda (jmolenda@apple.com) 1105 1106 * RNBRemote.h: Add set_max_packet_size. 1107 * RNBRemote.cpp: Add QSetMaxPacketSize packet handling. 1108 11092008-02-18 Greg Clayton <gclayton@apple.com> 1110 1111 * test-remotenub.cpp (HandleProcessStateChange): Call new 1112 RNBRemote::FlushSTDIO function. 1113 (RNBRunLoopInferiorExecuting): Ditto. 1114 * RNBRemote.h (RNBRemote::FlushSTDIO): New prototype. 1115 * RNBRemote.cpp (RNBRemote::FlushSTDIO): New function to 1116 centralize the stdio. 1117 11182008-02-18 Greg Clayton <gclayton@apple.com> 1119 1120 * DNB.cpp (DNBProcessWaitForEvent): Added timeout pointer as 1121 parameter that can be NULL for infinite timeout to simplify 1122 the DNB interface. 1123 (DNBProcessTimedWaitForEvent): Removed function. 1124 * DNB.h (DNBProcessWaitForEvent): Added timeout argument. 1125 (DNBProcessTimedWaitForEvent): Removed prototype. 1126 * DNBTimer.h (DNBTimer::OffsetTimeOfDay): New function. 1127 * CFString.cpp (CFString::GetLength() const): New function. 1128 * CFString.h (CFString::GetLength() const): New prototype. 1129 * MachProcess.h (MachProcess class): Removed m_attached and 1130 added m_flags. 1131 * MachProcess.cpp (MachProcess::AttachForDebug): Set m_flags 1132 to indicate we attached. 1133 (MachProcess::SBLaunchForDebug): Set m_flags to indicate we 1134 attached using SpringBoard and that we attached. 1135 (MachProcess::SBForkChildForPTraceDebugging): Changed to new 1136 SpringBoardServices API. 1137 (MachProcess::ThreadFunctionException): Added code that will 1138 renew a watchdog assertion when we launch apps through 1139 SpringBoardServices. 1140 * PThreadEvent.cpp (PThreadEvent::WaitForSetEvents): Simplified 1141 PThreadEvent API to have only one version of WaitForSetEvents 1142 that has an optional timeout pointer argument. 1143 * RNBContext.cpp (RNBContext::StopProcessStatusThread): Adapt 1144 to new PThreadEvent API changes. 1145 (RNBContext::ThreadFunctionProcessStatus): Adapt to new 1146 DNBProcessWaitForEvent API changes. 1147 * RNBRemote.cpp (RNBRemote::StopReadRemoteDataThread): Adapt 1148 to new PThreadEvent API changes. 1149 * test-remotenub.cpp (RNBRunLoopLaunchInferior): Adapt to new 1150 DNBProcessWaitForEvent API changes. 1151 (RNBRunLoopInferiorExecuting): Process STDIO first, then 1152 incoming packets. 1153 11542008-02-14 Jason Molenda (jmolenda@apple.com) 1155 1156 * MachProcess.cpp: (MachProcess::SBForkChildForPTraceDebugging): 1157 Set mode bits on slave side of pty. 1158 11592008-02-12 Greg Clayton <gclayton@apple.com> 1160 1161 * DNB.cpp (DNBEnableLogging): Removed function. 1162 (DNBThreadPrintStopReason): Removed the file handle from this 1163 function and use DNBLog calls. 1164 * DNB.h (DNBEnableLogging): Removed function prototype. 1165 (DNBThreadPrintStopReason): Removed the file handle 1166 from the function prototype in favor of using DNBLog calls. 1167 * DNBDataRef.cpp (DNBDataRef::Dump): Removed file handle to use 1168 DNBLog for the logging and print a log line each time a full line 1169 is ready for output after caching it in a local buffer. 1170 * DNBDataRef.cpp (DNBDataRef::Dump): Removed file handle from 1171 prototype. 1172 * DNBDefs.h (DNBCallbackLog): New callback prototype for all 1173 logging. 1174 DNBLog.cpp(g_debug_opt): Renamed to d_debug and made it a file 1175 static. 1176 (DNBLogGetDebug): New accessor function for g_debug. 1177 (DNBLogSetDebug): New accessor function for g_debug. 1178 (g_verbose): Made into a file static and added accessors. 1179 (DNBLogGetVerbose): New accessor function for g_verbose. 1180 (DNBLogSetVerbose): New accessor function for g_verbose. 1181 (DNBLogSetLogCallback): New function call that registers a logging 1182 callback for all logging in libdebugnub.dylib and any code that 1183 loads it. 1184 (DNBLogToASL): Removed function as it is deprecated in favor of 1185 using DNBLogSetLogCallback to regsiter a callback function that 1186 implements the logging. 1187 (DNBLogToFile): Ditto. 1188 (DNBLogCloseLogFile): Ditto. 1189 (DNBLogToFile): Ditto. 1190 (DNBLogToFile): Ditto. 1191 (_DNBLogPuts): Removed unused function. 1192 (_DNBLogVAPrintf): Calls the callback function to do the logging 1193 if one has been registered. 1194 * DNBLog.h (DNBLOG_FLAG_FATAL): New defines that get passed to 1195 any registered logging callback functions. 1196 (DNBLOG_FLAG_FATAL): Ditto. 1197 (DNBLOG_FLAG_ERROR): Ditto. 1198 (DNBLOG_FLAG_WARNING): Ditto. 1199 (DNBLOG_FLAG_DEBUG): Ditto. 1200 (DNBLOG_FLAG_VERBOSE): Ditto. 1201 (DNBLOG_FLAG_THREADED): Ditto. 1202 (DNBLog*): All logging calls are now exported from libdebugnub.dylib 1203 so there aren't two copies (one in debugserver and one in debugnub). 1204 C99 vararg Macros wrap all logging calls so no var arg processing 1205 occurs when logging is disabled. 1206 * DNBRegisterInfo.cpp (DNBRegisterValueClass::Dump): Removed file 1207 handle and now use DNBLog calls. 1208 * DNBRegisterInfo.h (DNBRegisterValueClass::Dump): Removed file 1209 handle from prototype. 1210 * MachException.cpp (catch_mach_exception_raise_state_identity): 1211 Removed newlines from logging call. 1212 (catch_mach_exception_raise): Ditto. 1213 (MachException::Message::Dump): Removed file handle from params 1214 and removed newlines from logging call. 1215 (MachException::ThreadMessage::DumpStopReason): Removed file handle 1216 from params and use DNBLog for logging output. 1217 (MachException::ThreadMessage::Dump): Log using DNBLog instead of 1218 file handle. 1219 * MachProcess.cpp (MachProcess::DumpThreadStoppedReason): Ditto. 1220 (MachProcess::ReadMemory): Ditto. 1221 (MachProcess::WriteMemory): Ditto. 1222 (ExceptionMessageBundleComplete): Ditto. 1223 * MachThread.cpp (MachThread::Dump): Ditto. 1224 (MachThread::DumpRegisterState): Ditto. 1225 * MachThreadList.cpp (MachThreadList::DumpThreadStoppedReason): Ditto. 1226 (MachThreadList::Dump): Ditto. 1227 * RNBRemote.cpp (set_logging): Use new function callback registration 1228 calls when enabling ASL logging. 1229 test-remotenub.cpp (ASLLogCallback): New function to handle all ASL 1230 logging. This function gets registered with libdebugnub.dylib when we 1231 want to log using ASL. 1232 (FileLogCallback): New function to handle all file logging. This 1233 function gets registered with libdebugnub.dylib when we want to log 1234 to a 'FILE *'. 1235 (main): Register the logging callback functions when we want to log 1236 to file or using ASL. 1237 12382008-02-12 Greg Clayton <gclayton@apple.com> 1239 1240 * test-remotenub.cpp (main): Default to ASL logging with no log 1241 bits set to allow for warning and error logging. 1242 * RNBRemote.h (struct Breakpoint): New structure for ref counting 1243 breakpoints in Z and z packets. 1244 * RNBRemote.cpp (RNBRemote::SendPacket): Use new LOG_RNB_PACKETS 1245 defined when logging actual packet content. 1246 (RNBRemote::HandleAsyncPacket): Ditto. 1247 (RNBRemote::HandleReceivedPacket): Ditto. 1248 (RNBRemote::HandlePacket_z): Ref count the setting and removing 1249 of breakpoints with the Z and z packets using new struct 1250 RNBRemote::Breakpoint. 1251 * RNBDefs.h (LOG_RNB_PACKETS): New define for logging the sending 1252 and receiving of packets data. 1253 * DNB.cpp (DNBPrintf): Check for NULL file handle. 1254 * DNBBreakpoint.cpp (DNBBreakpoint::Dump): Ditto. 1255 (DNBBreakpointList::Dump): Ditto. 1256 * DNBDefs.h (LOG_EVENTS): New define for logging PThreadEvent. 1257 * DNBLog.cpp (g_debug_opt): Relocated outside of #if that turns off 1258 logging completely to allow option parsing code that uses it to 1259 still compile. 1260 (g_verbose): Ditto. 1261 * DNBLog.h (DNBLogToASL): Added prototype for when logging is 1262 disabled via preprocessor macro. 1263 (DNBLogToFile): Ditto. 1264 * DNBRegisterInfo.cpp (DNBRegisterValueClass::Dump): Check for NULL 1265 file handle. 1266 * MachException.cpp (MachException::ThreadMessage::DumpStopReason): Ditto. 1267 (MachException::ThreadMessage::Dump): Ditto. 1268 * MachProcess.cpp (MachProcess::CreateBreakpoint): Improved logging. 1269 (MachProcess::DisableBreakpoint): Verify the original opcode gets 1270 restored, improved logging and added unconditional logging for when 1271 things go wrong. 1272 (MachProcess::EnableBreakpoint): Verify the breakpoint opcode gets 1273 written, improved logging and added unconditional logging for when 1274 things go wrong. 1275 * MachThread.cpp (MachThread::Dump): Check for NULL file handle. 1276 * MachVMMemory.cpp (MachVMMemory::WriteRegion): Flush caches in inferior 1277 after writing to inferior memory. 1278 * PThreadEvent.cpp: Changed all logging calls to key off of LOG_EVENTS 1279 instead of LOG_VERBOSE. 1280 MachDYLD.cpp (MachDYLD::Dump): Check for NULL file handle. 1281 (MachDYLD::DYLIBInfo::Dump): Ditto. 1282 ProfileObjectiveC.cpp (ProfileObjectiveC::DumpStats): Ditto. 1283 12842008-02-09 Jason Molenda (jmolenda@apple.com) 1285 1286 * RNBRemote.cpp (set_logging): Log to ASL unconditionally when 1287 processing a QSetLogging packet. 1288 12892008-02-06 Greg Clayton <gclayton@apple.com> 1290 1291 * test-remotenub.cpp (main): Dup stdout and stderr to /dev/NULL 1292 when we use lockdown. 1293 12942008-02-06 Greg Clayton <gclayton@apple.com> 1295 1296 * RNBSocket.cpp (RNBSocket::Disconnect): Removed unused var ERR. 1297 * RNBRemote.cpp(RNBRemote::HandlePacket_Q): Removed unused var PID. 1298 * DNBError.cpp (DNBError::LogThreadedIfError): Removed unused var 1299 ERR_MSG. 1300 * test-remotenub.cpp (RNBRunLoopLaunchInferior): Removed unused 1301 variable EXECUTABLE_LENGTH. 1302 (main): Removed unused variable ARG_IDX. 1303 13042008-02-06 Chris Marcellino (cmarcellino@apple.com) and Myke Olson (molson@apple.com) 1305 1306 * MachProcess.cpp (SBForkChildForPTraceDebugging): Bring up to date with 1307 current SpringBoardServices.framework types and imports. 1308 13092008-02-05 Jason Molenda (jmolenda@apple.com) 1310 1311 * RNBRemote.cpp (set_logging): Remove the mode=file and filename= 1312 options to the QSetLogging packet. We're only going to support logging 1313 to ASL for now. Logging to a file can still be accomplished by the 1314 -l command line argument. 1315 13162008-02-02 Christopher Friesen (cfriesen@apple.com) 1317 1318 * Added libXcodeDebugerSupport.dylib target 1319 * XCDebuggerIntrospection.[hc]: Support for Xcode's debugger introspection. 1320 13212008-02-01 Jason Molenda (jmolenda@apple.com) 1322 1323 * DNBLog.cpp (DNBLogCloseLogFile): New function to close a logfile 1324 at exit. 1325 * DNBLog.h: Prototype. 1326 * test-remotenub.cpp (main): Close the log file before exiting. 1327 13282008-02-01 Jason Molenda (jmolenda@apple.com) 1329 1330 * RNBRemote.cpp (set_logging): Recognize the "filename=" argument 1331 to the QSetLogging directive. 1332 * DNBLog.cpp (DNBLogGetLogMask): New fun.c 1333 * DNBLog.h: Prototype. 1334 13352008-01-31 Jason Molenda (jmolenda@apple.com) 1336 1337 * DNBLog.cpp: Add ASL logging as a run-time selectable option. 1338 (DNBLogToASL, DNBLogToFile): Functions to switch between logging to 1339 a file and logging via ASL. 1340 * DNBLog.h: Prototypes. 1341 * RNBRemote.cpp (set_logging): Recognize the "mode=" field to enable 1342 asl logging. Skip unrecognized keys. 1343 13442008-01-31 Greg Clayton (gclayton@apple.com) 1345 1346 * DNB.cpp (sigchld_handler): Better logging when we get a 1347 SIGCHILD and we are watching for process related logging events. 1348 * test-remotenub.cpp (RNBRunLoopInferiorExecuting): Only reset 1349 events when we still have event bits set. 1350 13512008-01-29 Jason Molenda (jmolenda@apple.com) 1352 1353 * RNBRemote.h: Add set_logging_mode. 1354 * RNBRemote.cpp (RNBRemote::CreatePacketTable): Recognize 1355 QSetLogging. 1356 13572008-01-29 Jason Molenda (jmolenda@apple.com) 1358 1359 * RNBRemote.cpp (set_logging): New function to parse the QSetLogging 1360 packet. 1361 (RNBRemote::HandlePacket_Q): Call it. 1362 13632008-01-28 Jason Molenda (jmolenda@apple.com) 1364 1365 * RNBRemote.h: Minimal packet size is 1024 in our gdb now. 1366 * RNBRemote.cpp: Add the stop_pc value in big-endian order to the 1367 T response packet to make it a little easier to follow where gdb 1368 is stepping. 1369 13702008-01-28 Greg Clayton <gclayton@apple.com> 1371 1372 * RNBContext.h: Removed m_pid_state from RNBContext class so that 1373 it couldn't get out of sync with the actual process and its accessors 1374 SetProcessState() and GetProcessState(). 1375 * RNBContext.cpp (RNBContext::ProcessStateRunning): Always return the 1376 current state of the process instead of a cached value. 1377 * test-remotenub.cpp (RNBRunLoopLaunchInferior): Remove call to 1378 deprecated RNBContext::SetProcessState(). 1379 (HandleProcessStateChange): Ditto. 1380 13812008-01-24 Greg Clayton (gclayton@apple.com) 1382 1383 * RNBRemote.cpp (RNBRemote::HandlePacket_q): See if command starts with 1384 "qSymbol" (no trailing "s") and return the empty string. 1385 13862008-01-24 Greg Clayton (gclayton@apple.com) 1387 1388 * RNBRemote.cpp (RNBRemote::HandlePacket_q): See if command starts with 1389 "qSymbols" and return the empty string. 1390 13912008-01-24 Greg Clayton (gclayton@apple.com) 1392 1393 * DNBError.h (DNBError::DumpIfError): Removed prototype. 1394 * DNBError.cpp (DNBError::DumpIfError): Removed function. 1395 (DNBError::LogThreadedIfError): Output error as hex. 1396 * MachException.cpp (MachException::Message::Receive): Don't use 1397 DNBError::DumpIfError, now use DNBError::LogThreadedIfError. 1398 * MachProcess.cpp (MachProcess::StartExceptionThread): Ditto. 1399 (MachProcess::Suspend): Ditto. 1400 (MachProcess::SBForkChildForPTraceDebugging): Ditto. 1401 * MachVMMemory.cpp (MachVMMemory::Read): Cleaned up logging 1402 calls. 1403 (MachVMMemory::Write): Ditto. 1404 (MachVMMemory::WriteRegion): Added logging. 1405 * RNBContenxt.cpp (display_thread_info): Removed function. 1406 * RNBRemote.cpp (RNBRemote::GetPacket): Commented out stderr 1407 messages to avoid SpringBoard from killing us. 1408 (RNBRemote::HandlePacket_p): Ditto. 1409 (RNBRemote::HandlePacket_P): Ditto. 1410 (RNBRemote::HandlePacket_c): Ditto. 1411 (RNBRemote::HandlePacket_A): Removed code that was already 1412 * RNBSocket.cpp (RNBSocket::Listen): Commented out stdout 1413 messages to avoid SpringBoard from killing us. 1414 (RNBSocket::ConnectToService): Ditto. 1415 14162008-01-24 Jim Ingham <jingham@apple.com> 1417 1418 * RNBRemote.cpp (RNBRemote::HandlePacket_q): Reply "" to qSymbols 1419 and qOffsets. 1420 14212008-01-23 Jason Molenda (jmolenda@apple.com) 1422 1423 * RNBRemote.h: m_noack_mode to RNBRemote class. 1424 * RNBRemote.cpp: Change #ifdef NO_ACKS code blocks 1425 to use m_noack_mode instance variable. 1426 (RNBRemote::HandlePacket_Q): New function to handle 1427 QStartNoAckMode packet and set m_noack_mode appropriately. 1428 * test-remotenub.cpp: Remove NO_ACKS ifdefs. 1429 14302008-01-22 Jason Molenda (jmolenda@apple.com) 1431 1432 * RNBRemote.cpp (RNBRemote::CreatePacketTable): Recognize 1433 QStartNoAckMode as an unsupported remote protocol request. 1434 * RNBRemote.h: Add start_noack_mode enum entry. 1435 14362008-01-22 Greg Clayton (gclayton@apple.com) 1437 1438 * DNBLog.h: Removed C++ namespace for DNBLog (changed all DNBLog:: 1439 to DNBLog) so C99 var arg macros can be used to completely disable 1440 all logging and any functions that may be called when making the 1441 variable arguments. 1442 * DNBLog.cpp: Ditto. 1443 * DNB.cpp: Ditto. 1444 * DNBBreakpoint.cpp: Ditto. 1445 * DNBError.cpp: Ditto. 1446 * MacOSX/MachDYLD.cpp: Ditto. 1447 * MacOSX/MachException.cpp: Ditto. 1448 * MacOSX/MachProcess.cpp: Ditto. 1449 * MacOSX/MachThread.cpp: Ditto. 1450 * MacOSX/MachThreadList.cpp: Ditto. 1451 * MacOSX/MachVMMemory.cpp: Ditto. 1452 * MacOSX/MachVMRegion.cpp: Ditto. 1453 * MacOSX/arm/DNBArchImpl.cpp: Ditto. 1454 * MacOSX/ppc/DNBArchImpl.cpp: Ditto. 1455 * PThreadEvent.cpp: Ditto. 1456 * RNBContext.cpp: Ditto. 1457 * RNBRemote.cpp: Ditto. 1458 * RNBSocket.cpp: Ditto. 1459 * test-remotenub.cpp: Ditto. 1460 14612008-01-21 Jason Molenda (jmolenda@apple.com) 1462 1463 * test-remotenub.cpp: Add NO_SPRINGBOARD for turning off SpringBoard 1464 dependency ala NO_ACKS. 1465 14662008-01-18 Jason Molenda (jmolenda@apple.com) 1467 1468 * RNBSocket.h (RNBSocket::RNBSocket): Take either a port # or 1469 an already-opened socket, with a boolean to indicate which it is. 1470 * RNBRemote.cpp (RNBRemote::RNBRemote): Ditto. 1471 * RNBRemote.h: Prototype update. 1472 * test-remotenub.cpp: Include lockdown.h. Take --lockdown command 1473 line arg, get the socket from liblockdown.dylib instead of opening 1474 our own socket if it is specified. --lockdown indicates that 1475 the program name/args will be provided via remote protocol instead 1476 of on the command line. 1477 14782008-01-17 Jason Molenda (jmolenda@apple.com) 1479 1480 * RNBRemote.cpp: Add NO_ACKS #ifdefs around code that computes 1481 the checksums and sends/expects the gdb remote protocol ACK packets. 1482 If NO_ACKS is defined, debugserver will not send or expect acks. 1483 * test-remotenub.cpp (main): Print a different version string 1484 if NO_ACKS is defined. 1485 14862008-01-16 Greg Clayton (gclayton@apple.com) 1487 1488 * PThreadEvent.cpp: Added this pointer to all logging calls. 1489 14902008-01-16 Greg Clayton (gclayton@apple.com) 1491 1492 * RNBSocket.cpp (RNBSocket::Connect()): Use TCP so we can try the 1493 TCP_NODELAY socket option. 1494 (RNBSocket::SetSocketOption()): New function. 1495 * RNBSocket.h (RNBSocket::SetSocketOption()): New class function. 1496 14972008-01-14 Jason Molenda (jmolenda@apple.com) 1498 1499 * RNBRemote.cpp (RNBRemote::HandlePacket_last_signal): When printing 1500 registers, skip over gdb regs which don't map to DNB regs. 1501 15022008-01-14 Jim Ingham <jingham@apple.com> 1503 1504 * ChangeLog - created. 1505 * RBNContext.h: Added m_arg_vec and accessors. 1506 * RNBContext.cpp (SetProcessID): New function. 1507 * RBNRemote.h: Added packet type to HandlePacket & HandleAsyncPacket 1508 * RNBRemote.cpp (HandlePacket, HandleAsyncPacket): Return type. 1509 (HandlePacket_A): Fix a few bugs. 1510 (HandlePacket_H): Return OK if target is not yet running. 1511 (HandlePacket_q): Return PID of 0 if target is not yet running. 1512 * testremotenub.cpp (RNBRunLoopGetArgsFromRemote): Implement. 1513 (RNBRunLoopLaunchInferior): Fetch arguments from context. 1514 (main) Store arguments in context, call RNBRunLoopGetArgsFromRemote 1515 if appropriate. 1516