bootdevice: bug fixes
-----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.11 (GNU/Linux) iQEcBAABAgAGBQJU9UQvAAoJELp6ZbDd4w+7xGIH+wWRO2PEQptPazlRE/q0A1Hw zmAHVNq1HAjR5NmUQVmUK/Di/qShmK8Dq9/5PV2g2z//f82KnMcnpR8yX8WJjuOB Pw1UhAyVlq6qlCn+lsRMEIs06krJNkuEvUd/aqzfi18+cAyelVVEBik7Vu/d8Pl1 xaPUe8upEJuUMz/NqFVe88wED4vDRn6qzxv9OwuMh8dXQQxFM/lLeaU4n3Vtg5Ba BY00OBxeLP/+p1By2aZZLDx/X9wFmEaxVD1n5Qm9zdXkiACXweoAwjSWV0wTLdZN zoq10i25/mMs/wYd++MUefvVC9GXwk4IYxXG7jMtvclwKUxmlkCcfKCWEZw3npQ= =yBF7 -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/gonglei/tags/bootdevice-next-20150303' into staging bootdevice: bug fixes # gpg: Signature made Tue Mar 3 05:18:39 2015 GMT using RSA key ID DDE30FBB # gpg: Good signature from "Gonglei <arei.gonglei@huawei.com>" # gpg: WARNING: This key is not certified with a trusted signature! # gpg: There is no indication that the signature belongs to the owner. # Primary key fingerprint: 5178 9C82 617F 2F58 8693 63B1 BA7A 65B0 DDE3 0FBB * remotes/gonglei/tags/bootdevice-next-20150303: bootdevice: add check in restore_boot_order() bootdevice: check boot order argument validation before vm running Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
		
						commit
						fff795ab38
					
				| @ -105,7 +105,9 @@ void restore_boot_order(void *opaque) | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     qemu_boot_set(normal_boot_order, NULL); |     if (boot_set_handler) { | ||||||
|  |         qemu_boot_set(normal_boot_order, &error_abort); | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     qemu_unregister_reset(restore_boot_order, normal_boot_order); |     qemu_unregister_reset(restore_boot_order, normal_boot_order); | ||||||
|     g_free(normal_boot_order); |     g_free(normal_boot_order); | ||||||
|  | |||||||
							
								
								
									
										36
									
								
								vl.c
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								vl.c
									
									
									
									
									
								
							| @ -2733,7 +2733,8 @@ int main(int argc, char **argv, char **envp) | |||||||
|     int snapshot, linux_boot; |     int snapshot, linux_boot; | ||||||
|     const char *initrd_filename; |     const char *initrd_filename; | ||||||
|     const char *kernel_filename, *kernel_cmdline; |     const char *kernel_filename, *kernel_cmdline; | ||||||
|     const char *boot_order; |     const char *boot_order = NULL; | ||||||
|  |     const char *boot_once = NULL; | ||||||
|     DisplayState *ds; |     DisplayState *ds; | ||||||
|     int cyls, heads, secs, translation; |     int cyls, heads, secs, translation; | ||||||
|     QemuOpts *hda_opts = NULL, *opts, *machine_opts, *icount_opts = NULL; |     QemuOpts *hda_opts = NULL, *opts, *machine_opts, *icount_opts = NULL; | ||||||
| @ -4048,39 +4049,36 @@ int main(int argc, char **argv, char **envp) | |||||||
|     kernel_cmdline = qemu_opt_get(machine_opts, "append"); |     kernel_cmdline = qemu_opt_get(machine_opts, "append"); | ||||||
|     bios_name = qemu_opt_get(machine_opts, "firmware"); |     bios_name = qemu_opt_get(machine_opts, "firmware"); | ||||||
| 
 | 
 | ||||||
|     boot_order = machine_class->default_boot_order; |  | ||||||
|     opts = qemu_opts_find(qemu_find_opts("boot-opts"), NULL); |     opts = qemu_opts_find(qemu_find_opts("boot-opts"), NULL); | ||||||
|     if (opts) { |     if (opts) { | ||||||
|         char *normal_boot_order; |  | ||||||
|         const char *order, *once; |  | ||||||
|         Error *local_err = NULL; |         Error *local_err = NULL; | ||||||
| 
 | 
 | ||||||
|         order = qemu_opt_get(opts, "order"); |         boot_order = qemu_opt_get(opts, "order"); | ||||||
|         if (order) { |         if (boot_order) { | ||||||
|             validate_bootdevices(order, &local_err); |             validate_bootdevices(boot_order, &local_err); | ||||||
|             if (local_err) { |             if (local_err) { | ||||||
|                 error_report_err(local_err); |                 error_report_err(local_err); | ||||||
|                 exit(1); |                 exit(1); | ||||||
|             } |             } | ||||||
|             boot_order = order; |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         once = qemu_opt_get(opts, "once"); |         boot_once = qemu_opt_get(opts, "once"); | ||||||
|         if (once) { |         if (boot_once) { | ||||||
|             validate_bootdevices(once, &local_err); |             validate_bootdevices(boot_once, &local_err); | ||||||
|             if (local_err) { |             if (local_err) { | ||||||
|                 error_report_err(local_err); |                 error_report_err(local_err); | ||||||
|                 exit(1); |                 exit(1); | ||||||
|             } |             } | ||||||
|             normal_boot_order = g_strdup(boot_order); |  | ||||||
|             boot_order = once; |  | ||||||
|             qemu_register_reset(restore_boot_order, normal_boot_order); |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         boot_menu = qemu_opt_get_bool(opts, "menu", boot_menu); |         boot_menu = qemu_opt_get_bool(opts, "menu", boot_menu); | ||||||
|         boot_strict = qemu_opt_get_bool(opts, "strict", false); |         boot_strict = qemu_opt_get_bool(opts, "strict", false); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     if (!boot_order) { | ||||||
|  |         boot_order = machine_class->default_boot_order; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     if (!kernel_cmdline) { |     if (!kernel_cmdline) { | ||||||
|         kernel_cmdline = ""; |         kernel_cmdline = ""; | ||||||
|         current_machine->kernel_cmdline = (char *)kernel_cmdline; |         current_machine->kernel_cmdline = (char *)kernel_cmdline; | ||||||
| @ -4244,6 +4242,16 @@ int main(int argc, char **argv, char **envp) | |||||||
| 
 | 
 | ||||||
|     net_check_clients(); |     net_check_clients(); | ||||||
| 
 | 
 | ||||||
|  |     if (boot_once) { | ||||||
|  |         Error *local_err = NULL; | ||||||
|  |         qemu_boot_set(boot_once, &local_err); | ||||||
|  |         if (local_err) { | ||||||
|  |             error_report("%s", error_get_pretty(local_err)); | ||||||
|  |             exit(1); | ||||||
|  |         } | ||||||
|  |         qemu_register_reset(restore_boot_order, g_strdup(boot_order)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     ds = init_displaystate(); |     ds = init_displaystate(); | ||||||
| 
 | 
 | ||||||
|     /* init local displays */ |     /* init local displays */ | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Peter Maydell
						Peter Maydell