mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-26 03:33:28 +00:00 
			
		
		
		
	 726401be06
			
		
	
	
		726401be06
		
	
	
	
	
		
			
			The existing default_config_files table in arch_init.c has a single entry, making it completely unnecessary. The whole code can be replaced by a single qemu_read_config_file() call in vl.c. Signed-off-by: Eduardo Habkost <ehabkost@redhat.com> Message-Id: <20170117180051.11958-1-ehabkost@redhat.com> Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
		
			
				
	
	
		
			237 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			237 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * QEMU System Emulator
 | |
|  *
 | |
|  * Copyright (c) 2003-2008 Fabrice Bellard
 | |
|  *
 | |
|  * Permission is hereby granted, free of charge, to any person obtaining a copy
 | |
|  * of this software and associated documentation files (the "Software"), to deal
 | |
|  * in the Software without restriction, including without limitation the rights
 | |
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | |
|  * copies of the Software, and to permit persons to whom the Software is
 | |
|  * furnished to do so, subject to the following conditions:
 | |
|  *
 | |
|  * The above copyright notice and this permission notice shall be included in
 | |
|  * all copies or substantial portions of the Software.
 | |
|  *
 | |
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | |
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | |
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
 | |
|  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | |
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | |
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | |
|  * THE SOFTWARE.
 | |
|  */
 | |
| #include "qemu/osdep.h"
 | |
| #include "qemu-common.h"
 | |
| #include "cpu.h"
 | |
| #include "sysemu/sysemu.h"
 | |
| #include "sysemu/arch_init.h"
 | |
| #include "hw/pci/pci.h"
 | |
| #include "hw/audio/audio.h"
 | |
| #include "qemu/config-file.h"
 | |
| #include "qemu/error-report.h"
 | |
| #include "qmp-commands.h"
 | |
| #include "hw/acpi/acpi.h"
 | |
| #include "qemu/help_option.h"
 | |
| 
 | |
| #ifdef TARGET_SPARC
 | |
| int graphic_width = 1024;
 | |
| int graphic_height = 768;
 | |
| int graphic_depth = 8;
 | |
| #else
 | |
| int graphic_width = 800;
 | |
| int graphic_height = 600;
 | |
| int graphic_depth = 32;
 | |
| #endif
 | |
| 
 | |
| 
 | |
| #if defined(TARGET_ALPHA)
 | |
| #define QEMU_ARCH QEMU_ARCH_ALPHA
 | |
| #elif defined(TARGET_ARM)
 | |
| #define QEMU_ARCH QEMU_ARCH_ARM
 | |
| #elif defined(TARGET_CRIS)
 | |
| #define QEMU_ARCH QEMU_ARCH_CRIS
 | |
| #elif defined(TARGET_I386)
 | |
| #define QEMU_ARCH QEMU_ARCH_I386
 | |
| #elif defined(TARGET_M68K)
 | |
| #define QEMU_ARCH QEMU_ARCH_M68K
 | |
| #elif defined(TARGET_LM32)
 | |
| #define QEMU_ARCH QEMU_ARCH_LM32
 | |
| #elif defined(TARGET_MICROBLAZE)
 | |
| #define QEMU_ARCH QEMU_ARCH_MICROBLAZE
 | |
| #elif defined(TARGET_MIPS)
 | |
| #define QEMU_ARCH QEMU_ARCH_MIPS
 | |
| #elif defined(TARGET_MOXIE)
 | |
| #define QEMU_ARCH QEMU_ARCH_MOXIE
 | |
| #elif defined(TARGET_OPENRISC)
 | |
| #define QEMU_ARCH QEMU_ARCH_OPENRISC
 | |
| #elif defined(TARGET_PPC)
 | |
| #define QEMU_ARCH QEMU_ARCH_PPC
 | |
| #elif defined(TARGET_S390X)
 | |
| #define QEMU_ARCH QEMU_ARCH_S390X
 | |
| #elif defined(TARGET_SH4)
 | |
| #define QEMU_ARCH QEMU_ARCH_SH4
 | |
| #elif defined(TARGET_SPARC)
 | |
| #define QEMU_ARCH QEMU_ARCH_SPARC
 | |
| #elif defined(TARGET_XTENSA)
 | |
| #define QEMU_ARCH QEMU_ARCH_XTENSA
 | |
| #elif defined(TARGET_UNICORE32)
 | |
| #define QEMU_ARCH QEMU_ARCH_UNICORE32
 | |
| #elif defined(TARGET_TRICORE)
 | |
| #define QEMU_ARCH QEMU_ARCH_TRICORE
 | |
| #endif
 | |
| 
 | |
| const uint32_t arch_type = QEMU_ARCH;
 | |
| 
 | |
| struct soundhw {
 | |
|     const char *name;
 | |
|     const char *descr;
 | |
|     int enabled;
 | |
|     int isa;
 | |
|     union {
 | |
|         int (*init_isa) (ISABus *bus);
 | |
|         int (*init_pci) (PCIBus *bus);
 | |
|     } init;
 | |
| };
 | |
| 
 | |
| static struct soundhw soundhw[9];
 | |
| static int soundhw_count;
 | |
| 
 | |
| void isa_register_soundhw(const char *name, const char *descr,
 | |
|                           int (*init_isa)(ISABus *bus))
 | |
| {
 | |
|     assert(soundhw_count < ARRAY_SIZE(soundhw) - 1);
 | |
|     soundhw[soundhw_count].name = name;
 | |
|     soundhw[soundhw_count].descr = descr;
 | |
|     soundhw[soundhw_count].isa = 1;
 | |
|     soundhw[soundhw_count].init.init_isa = init_isa;
 | |
|     soundhw_count++;
 | |
| }
 | |
| 
 | |
| void pci_register_soundhw(const char *name, const char *descr,
 | |
|                           int (*init_pci)(PCIBus *bus))
 | |
| {
 | |
|     assert(soundhw_count < ARRAY_SIZE(soundhw) - 1);
 | |
|     soundhw[soundhw_count].name = name;
 | |
|     soundhw[soundhw_count].descr = descr;
 | |
|     soundhw[soundhw_count].isa = 0;
 | |
|     soundhw[soundhw_count].init.init_pci = init_pci;
 | |
|     soundhw_count++;
 | |
| }
 | |
| 
 | |
| void select_soundhw(const char *optarg)
 | |
| {
 | |
|     struct soundhw *c;
 | |
| 
 | |
|     if (is_help_option(optarg)) {
 | |
|     show_valid_cards:
 | |
| 
 | |
|         if (soundhw_count) {
 | |
|              printf("Valid sound card names (comma separated):\n");
 | |
|              for (c = soundhw; c->name; ++c) {
 | |
|                  printf ("%-11s %s\n", c->name, c->descr);
 | |
|              }
 | |
|              printf("\n-soundhw all will enable all of the above\n");
 | |
|         } else {
 | |
|              printf("Machine has no user-selectable audio hardware "
 | |
|                     "(it may or may not have always-present audio hardware).\n");
 | |
|         }
 | |
|         exit(!is_help_option(optarg));
 | |
|     }
 | |
|     else {
 | |
|         size_t l;
 | |
|         const char *p;
 | |
|         char *e;
 | |
|         int bad_card = 0;
 | |
| 
 | |
|         if (!strcmp(optarg, "all")) {
 | |
|             for (c = soundhw; c->name; ++c) {
 | |
|                 c->enabled = 1;
 | |
|             }
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         p = optarg;
 | |
|         while (*p) {
 | |
|             e = strchr(p, ',');
 | |
|             l = !e ? strlen(p) : (size_t) (e - p);
 | |
| 
 | |
|             for (c = soundhw; c->name; ++c) {
 | |
|                 if (!strncmp(c->name, p, l) && !c->name[l]) {
 | |
|                     c->enabled = 1;
 | |
|                     break;
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             if (!c->name) {
 | |
|                 if (l > 80) {
 | |
|                     error_report("Unknown sound card name (too big to show)");
 | |
|                 }
 | |
|                 else {
 | |
|                     error_report("Unknown sound card name `%.*s'",
 | |
|                                  (int) l, p);
 | |
|                 }
 | |
|                 bad_card = 1;
 | |
|             }
 | |
|             p += l + (e != NULL);
 | |
|         }
 | |
| 
 | |
|         if (bad_card) {
 | |
|             goto show_valid_cards;
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| void audio_init(void)
 | |
| {
 | |
|     struct soundhw *c;
 | |
|     ISABus *isa_bus = (ISABus *) object_resolve_path_type("", TYPE_ISA_BUS, NULL);
 | |
|     PCIBus *pci_bus = (PCIBus *) object_resolve_path_type("", TYPE_PCI_BUS, NULL);
 | |
| 
 | |
|     for (c = soundhw; c->name; ++c) {
 | |
|         if (c->enabled) {
 | |
|             if (c->isa) {
 | |
|                 if (!isa_bus) {
 | |
|                     error_report("ISA bus not available for %s", c->name);
 | |
|                     exit(1);
 | |
|                 }
 | |
|                 c->init.init_isa(isa_bus);
 | |
|             } else {
 | |
|                 if (!pci_bus) {
 | |
|                     error_report("PCI bus not available for %s", c->name);
 | |
|                     exit(1);
 | |
|                 }
 | |
|                 c->init.init_pci(pci_bus);
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| int kvm_available(void)
 | |
| {
 | |
| #ifdef CONFIG_KVM
 | |
|     return 1;
 | |
| #else
 | |
|     return 0;
 | |
| #endif
 | |
| }
 | |
| 
 | |
| int xen_available(void)
 | |
| {
 | |
| #ifdef CONFIG_XEN
 | |
|     return 1;
 | |
| #else
 | |
|     return 0;
 | |
| #endif
 | |
| }
 | |
| 
 | |
| 
 | |
| TargetInfo *qmp_query_target(Error **errp)
 | |
| {
 | |
|     TargetInfo *info = g_malloc0(sizeof(*info));
 | |
| 
 | |
|     info->arch = g_strdup(TARGET_NAME);
 | |
| 
 | |
|     return info;
 | |
| }
 |