| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  | #!/usr/bin/env python3 | 
					
						
							|  |  |  | # | 
					
						
							| 
									
										
										
										
											2021-09-27 14:48:02 +10:00
										 |  |  | # Test that Linux kernel boots on ppc machines and check the console | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # Copyright (c) 2018, 2020 Red Hat, Inc. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # This work is licensed under the terms of the GNU GPL, version 2 or | 
					
						
							|  |  |  | # later.  See the COPYING file in the top-level directory. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  | from qemu_test import QemuSystemTest, Asset | 
					
						
							|  |  |  | from qemu_test import wait_for_console_pattern | 
					
						
							| 
									
										
										
										
											2021-09-27 14:48:02 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 18:14:33 +02:00
										 |  |  | class pseriesMachine(QemuSystemTest): | 
					
						
							| 
									
										
										
										
											2021-09-27 14:48:02 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  |     timeout = 90 | 
					
						
							| 
									
										
										
										
											2023-10-05 19:28:08 +10:00
										 |  |  |     KERNEL_COMMON_COMMAND_LINE = 'printk.time=0 console=hvc0 ' | 
					
						
							| 
									
										
										
										
											2021-09-27 14:48:02 +10:00
										 |  |  |     panic_message = 'Kernel panic - not syncing' | 
					
						
							| 
									
										
										
										
											2023-06-22 19:33:57 +10:00
										 |  |  |     good_message = 'VFS: Cannot open root device' | 
					
						
							| 
									
										
										
										
											2021-09-27 14:48:02 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  |     ASSET_KERNEL = Asset( | 
					
						
							|  |  |  |         ('https://archives.fedoraproject.org/pub/archive/fedora-secondary/' | 
					
						
							|  |  |  |          'releases/29/Everything/ppc64le/os/ppc/ppc64/vmlinuz'), | 
					
						
							|  |  |  |         '383c2f5c23bc0d9d32680c3924d3fd7ee25cc5ef97091ac1aa5e1d853422fc5f') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-05 19:28:08 +10:00
										 |  |  |     def do_test_ppc64_linux_boot(self, kernel_command_line = KERNEL_COMMON_COMMAND_LINE): | 
					
						
							| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  |         kernel_path = self.ASSET_KERNEL.fetch() | 
					
						
							| 
									
										
										
										
											2021-09-27 14:48:02 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  |         self.vm.set_console() | 
					
						
							|  |  |  |         self.vm.add_args('-kernel', kernel_path, | 
					
						
							|  |  |  |                          '-append', kernel_command_line) | 
					
						
							|  |  |  |         self.vm.launch() | 
					
						
							| 
									
										
										
										
											2023-06-22 19:33:57 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-23 22:21:35 +10:00
										 |  |  |     def test_ppc64_vof_linux_boot(self): | 
					
						
							| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  |         self.set_machine('pseries') | 
					
						
							| 
									
										
										
										
											2023-06-23 22:21:35 +10:00
										 |  |  |         self.vm.add_args('-machine', 'x-vof=on') | 
					
						
							|  |  |  |         self.do_test_ppc64_linux_boot() | 
					
						
							|  |  |  |         console_pattern = 'VFS: Cannot open root device' | 
					
						
							|  |  |  |         wait_for_console_pattern(self, console_pattern, self.panic_message) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-22 19:33:57 +10:00
										 |  |  |     def test_ppc64_linux_boot(self): | 
					
						
							| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  |         self.set_machine('pseries') | 
					
						
							| 
									
										
										
										
											2023-06-22 19:33:57 +10:00
										 |  |  |         self.do_test_ppc64_linux_boot() | 
					
						
							| 
									
										
										
										
											2023-06-22 19:33:56 +10:00
										 |  |  |         console_pattern = 'VFS: Cannot open root device' | 
					
						
							| 
									
										
										
										
											2021-09-27 14:48:02 +10:00
										 |  |  |         wait_for_console_pattern(self, console_pattern, self.panic_message) | 
					
						
							| 
									
										
										
										
											2023-06-22 19:33:57 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_ppc64_linux_smp_boot(self): | 
					
						
							| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  |         self.set_machine('pseries') | 
					
						
							| 
									
										
										
										
											2023-06-22 19:33:57 +10:00
										 |  |  |         self.vm.add_args('-smp', '4') | 
					
						
							|  |  |  |         self.do_test_ppc64_linux_boot() | 
					
						
							|  |  |  |         console_pattern = 'smp: Brought up 1 node, 4 CPUs' | 
					
						
							|  |  |  |         wait_for_console_pattern(self, console_pattern, self.panic_message) | 
					
						
							|  |  |  |         wait_for_console_pattern(self, self.good_message, self.panic_message) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-05 19:28:08 +10:00
										 |  |  |     def test_ppc64_linux_hpt_smp_boot(self): | 
					
						
							| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  |         self.set_machine('pseries') | 
					
						
							| 
									
										
										
										
											2023-10-05 19:28:08 +10:00
										 |  |  |         self.vm.add_args('-smp', '4') | 
					
						
							|  |  |  |         self.do_test_ppc64_linux_boot(self.KERNEL_COMMON_COMMAND_LINE + | 
					
						
							|  |  |  |                                       'disable_radix') | 
					
						
							|  |  |  |         console_pattern = 'smp: Brought up 1 node, 4 CPUs' | 
					
						
							|  |  |  |         wait_for_console_pattern(self, 'hash-mmu: Initializing hash mmu', | 
					
						
							|  |  |  |                                  self.panic_message) | 
					
						
							|  |  |  |         wait_for_console_pattern(self, console_pattern, self.panic_message) | 
					
						
							|  |  |  |         wait_for_console_pattern(self, self.good_message, self.panic_message) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-22 19:33:57 +10:00
										 |  |  |     def test_ppc64_linux_smt_boot(self): | 
					
						
							|  |  |  |         self.vm.add_args('-smp', '4,threads=4') | 
					
						
							|  |  |  |         self.do_test_ppc64_linux_boot() | 
					
						
							|  |  |  |         console_pattern = 'CPU maps initialized for 4 threads per core' | 
					
						
							|  |  |  |         wait_for_console_pattern(self, console_pattern, self.panic_message) | 
					
						
							|  |  |  |         console_pattern = 'smp: Brought up 1 node, 4 CPUs' | 
					
						
							|  |  |  |         wait_for_console_pattern(self, console_pattern, self.panic_message) | 
					
						
							|  |  |  |         wait_for_console_pattern(self, self.good_message, self.panic_message) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_ppc64_linux_big_boot(self): | 
					
						
							| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  |         self.set_machine('pseries') | 
					
						
							| 
									
										
										
										
											2023-06-22 19:33:57 +10:00
										 |  |  |         self.vm.add_args('-smp', '16,threads=4,cores=2,sockets=2') | 
					
						
							|  |  |  |         self.vm.add_args('-m', '512M', | 
					
						
							|  |  |  |                          '-object', 'memory-backend-ram,size=256M,id=m0', | 
					
						
							|  |  |  |                          '-object', 'memory-backend-ram,size=256M,id=m1') | 
					
						
							|  |  |  |         self.vm.add_args('-numa', 'node,nodeid=0,memdev=m0') | 
					
						
							|  |  |  |         self.vm.add_args('-numa', 'node,nodeid=1,memdev=m1') | 
					
						
							|  |  |  |         self.do_test_ppc64_linux_boot() | 
					
						
							|  |  |  |         console_pattern = 'CPU maps initialized for 4 threads per core' | 
					
						
							|  |  |  |         wait_for_console_pattern(self, console_pattern, self.panic_message) | 
					
						
							|  |  |  |         console_pattern = 'smp: Brought up 2 nodes, 16 CPUs' | 
					
						
							|  |  |  |         wait_for_console_pattern(self, console_pattern, self.panic_message) | 
					
						
							|  |  |  |         wait_for_console_pattern(self, self.good_message, self.panic_message) | 
					
						
							| 
									
										
										
										
											2024-08-30 15:38:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | if __name__ == '__main__': | 
					
						
							|  |  |  |     QemuSystemTest.main() |