mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-22 13:05:52 -04:00

*** to conform to clang-format’s LLVM style. This kind of mass change has *** two obvious implications: Firstly, merging this particular commit into a downstream fork may be a huge effort. Alternatively, it may be worth merging all changes up to this commit, performing the same reformatting operation locally, and then discarding the merge for this particular commit. The commands used to accomplish this reformatting were as follows (with current working directory as the root of the repository): find . \( -iname "*.c" -or -iname "*.cpp" -or -iname "*.h" -or -iname "*.mm" \) -exec clang-format -i {} + find . -iname "*.py" -exec autopep8 --in-place --aggressive --aggressive {} + ; The version of clang-format used was 3.9.0, and autopep8 was 1.2.4. Secondly, “blame” style tools will generally point to this commit instead of a meaningful prior commit. There are alternatives available that will attempt to look through this change and find the appropriate prior commit. YMMV. llvm-svn: 280751
128 lines
4.6 KiB
Python
128 lines
4.6 KiB
Python
"""
|
|
Use lldb Python SBTarget API to iterate on the watchpoint(s) for the target.
|
|
"""
|
|
|
|
from __future__ import print_function
|
|
|
|
|
|
import os
|
|
import re
|
|
import time
|
|
|
|
import lldb
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
|
|
class WatchpointIteratorTestCase(TestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
def setUp(self):
|
|
# Call super's setUp().
|
|
TestBase.setUp(self)
|
|
# Our simple source filename.
|
|
self.source = 'main.c'
|
|
# Find the line number to break inside main().
|
|
self.line = line_number(
|
|
self.source, '// Set break point at this line.')
|
|
|
|
@add_test_categories(['pyapi'])
|
|
# Watchpoints not supported
|
|
@expectedFailureAndroid(archs=['arm', 'aarch64'])
|
|
@expectedFailureAll(
|
|
oslist=["windows"],
|
|
bugnumber="llvm.org/pr24446: WINDOWS XFAIL TRIAGE - Watchpoints not supported on Windows")
|
|
def test_watch_iter(self):
|
|
"""Exercise SBTarget.watchpoint_iter() API to iterate on the available watchpoints."""
|
|
self.build()
|
|
exe = os.path.join(os.getcwd(), "a.out")
|
|
|
|
# Create a target by the debugger.
|
|
target = self.dbg.CreateTarget(exe)
|
|
self.assertTrue(target, VALID_TARGET)
|
|
|
|
# Create a breakpoint on main.c in order to set our watchpoint later.
|
|
breakpoint = target.BreakpointCreateByLocation(self.source, self.line)
|
|
self.assertTrue(breakpoint and
|
|
breakpoint.GetNumLocations() == 1,
|
|
VALID_BREAKPOINT)
|
|
|
|
# Now launch the process, and do not stop at the entry point.
|
|
process = target.LaunchSimple(
|
|
None, None, self.get_process_working_directory())
|
|
|
|
# We should be stopped due to the breakpoint. Get frame #0.
|
|
process = target.GetProcess()
|
|
self.assertTrue(process.GetState() == lldb.eStateStopped,
|
|
PROCESS_STOPPED)
|
|
thread = lldbutil.get_stopped_thread(
|
|
process, lldb.eStopReasonBreakpoint)
|
|
frame0 = thread.GetFrameAtIndex(0)
|
|
|
|
# Watch 'global' for read and write.
|
|
value = frame0.FindValue('global', lldb.eValueTypeVariableGlobal)
|
|
error = lldb.SBError()
|
|
watchpoint = value.Watch(True, False, True, error)
|
|
self.assertTrue(value and watchpoint,
|
|
"Successfully found the variable and set a watchpoint")
|
|
self.DebugSBValue(value)
|
|
|
|
# Hide stdout if not running with '-t' option.
|
|
if not self.TraceOn():
|
|
self.HideStdout()
|
|
|
|
# There should be only 1 watchpoint location under the target.
|
|
self.assertTrue(target.GetNumWatchpoints() == 1)
|
|
self.assertTrue(watchpoint.IsEnabled())
|
|
watch_id = watchpoint.GetID()
|
|
self.assertTrue(watch_id != 0)
|
|
|
|
# Continue. Expect the program to stop due to the variable being
|
|
# written to.
|
|
process.Continue()
|
|
|
|
# Hide stdout if not running with '-t' option.
|
|
if not self.TraceOn():
|
|
self.HideStdout()
|
|
|
|
# Print the stack traces.
|
|
lldbutil.print_stacktraces(process)
|
|
|
|
thread = lldbutil.get_stopped_thread(
|
|
process, lldb.eStopReasonWatchpoint)
|
|
self.assertTrue(thread, "The thread stopped due to watchpoint")
|
|
self.DebugSBValue(value)
|
|
|
|
# We currently only support hardware watchpoint. Verify that we have a
|
|
# meaningful hardware index at this point. Exercise the printed repr of
|
|
# SBWatchpointLocation.
|
|
print(watchpoint)
|
|
self.assertTrue(watchpoint.GetHardwareIndex() != -1)
|
|
|
|
# SBWatchpoint.GetDescription() takes a description level arg.
|
|
print(lldbutil.get_description(watchpoint, lldb.eDescriptionLevelFull))
|
|
|
|
# Now disable the 'rw' watchpoint. The program won't stop when it reads
|
|
# 'global' next.
|
|
watchpoint.SetEnabled(False)
|
|
self.assertTrue(watchpoint.GetHardwareIndex() == -1)
|
|
self.assertFalse(watchpoint.IsEnabled())
|
|
|
|
# Continue. The program does not stop again when the variable is being
|
|
# read from because the watchpoint location has been disabled.
|
|
process.Continue()
|
|
|
|
# At this point, the inferior process should have exited.
|
|
self.assertTrue(
|
|
process.GetState() == lldb.eStateExited,
|
|
PROCESS_EXITED)
|
|
|
|
# Verify some vital statistics and exercise the iterator API.
|
|
for watchpoint in target.watchpoint_iter():
|
|
self.assertTrue(watchpoint)
|
|
self.assertTrue(watchpoint.GetWatchSize() == 4)
|
|
self.assertTrue(watchpoint.GetHitCount() == 1)
|
|
print(watchpoint)
|