199451b44SJordan Rupprecht""" 299451b44SJordan RupprechtTest the MemoryCache L1 flush. 399451b44SJordan Rupprecht""" 499451b44SJordan Rupprecht 599451b44SJordan Rupprecht 699451b44SJordan Rupprecht 799451b44SJordan Rupprechtimport lldb 899451b44SJordan Rupprechtfrom lldbsuite.test.decorators import * 999451b44SJordan Rupprechtfrom lldbsuite.test.lldbtest import * 1099451b44SJordan Rupprechtimport lldbsuite.test.lldbutil as lldbutil 1199451b44SJordan Rupprecht 1299451b44SJordan Rupprecht 1399451b44SJordan Rupprechtclass MemoryCacheTestCase(TestBase): 1499451b44SJordan Rupprecht 1599451b44SJordan Rupprecht def setUp(self): 1699451b44SJordan Rupprecht # Call super's setUp(). 1799451b44SJordan Rupprecht TestBase.setUp(self) 1899451b44SJordan Rupprecht # Find the line number to break inside main(). 1999451b44SJordan Rupprecht self.line = line_number('main.cpp', '// Set break point at this line.') 2099451b44SJordan Rupprecht 2199451b44SJordan Rupprecht @skipIfWindows # This is flakey on Windows: llvm.org/pr38373 2299451b44SJordan Rupprecht def test_memory_cache(self): 2399451b44SJordan Rupprecht """Test the MemoryCache class with a sequence of 'memory read' and 'memory write' operations.""" 2499451b44SJordan Rupprecht self.build() 2599451b44SJordan Rupprecht exe = self.getBuildArtifact("a.out") 2699451b44SJordan Rupprecht self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET) 2799451b44SJordan Rupprecht 2899451b44SJordan Rupprecht # Break in main() after the variables are assigned values. 2999451b44SJordan Rupprecht lldbutil.run_break_set_by_file_and_line( 3099451b44SJordan Rupprecht self, "main.cpp", self.line, num_expected_locations=1, loc_exact=True) 3199451b44SJordan Rupprecht 3299451b44SJordan Rupprecht self.runCmd("run", RUN_SUCCEEDED) 3399451b44SJordan Rupprecht 3499451b44SJordan Rupprecht # The stop reason of the thread should be breakpoint. 3599451b44SJordan Rupprecht self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT, 3699451b44SJordan Rupprecht substrs=['stopped', 'stop reason = breakpoint']) 3799451b44SJordan Rupprecht 3899451b44SJordan Rupprecht # The breakpoint should have a hit count of 1. 39*9f0b5f9aSSYNOPSYS\georgiev lldbutil.check_breakpoint(self, bpno = 1, expected_hit_count = 1) 4099451b44SJordan Rupprecht 4199451b44SJordan Rupprecht # Read a chunk of memory containing &my_ints[0]. The number of bytes read 4299451b44SJordan Rupprecht # must be greater than m_L2_cache_line_byte_size to make sure the L1 4399451b44SJordan Rupprecht # cache is used. 4499451b44SJordan Rupprecht self.runCmd('memory read -f d -c 201 `&my_ints - 100`') 4599451b44SJordan Rupprecht 4699451b44SJordan Rupprecht # Check the value of my_ints[0] is the same as set in main.cpp. 4799451b44SJordan Rupprecht line = self.res.GetOutput().splitlines()[100] 48b3a0c4d7SRaphael Isemann self.assertEquals(0x00000042, int(line.split(':')[1], 0)) 4999451b44SJordan Rupprecht 5099451b44SJordan Rupprecht # Change the value of my_ints[0] in memory. 5199451b44SJordan Rupprecht self.runCmd("memory write -s 4 `&my_ints` AA") 5299451b44SJordan Rupprecht 5399451b44SJordan Rupprecht # Re-read the chunk of memory. The cache line should have been 5499451b44SJordan Rupprecht # flushed because of the 'memory write'. 5599451b44SJordan Rupprecht self.runCmd('memory read -f d -c 201 `&my_ints - 100`') 5699451b44SJordan Rupprecht 5799451b44SJordan Rupprecht # Check the value of my_ints[0] have been updated correctly. 5899451b44SJordan Rupprecht line = self.res.GetOutput().splitlines()[100] 59b3a0c4d7SRaphael Isemann self.assertEquals(0x000000AA, int(line.split(':')[1], 0)) 60