Eduardo Habkost | a1a9cb0 | 2014-09-26 17:45:17 -0300 | [diff] [blame] | 1 | /* |
Claudio Fontana | 940e43a | 2021-02-04 17:39:24 +0100 | [diff] [blame] | 2 | * QEMU accel class, system emulation components |
Eduardo Habkost | a1a9cb0 | 2014-09-26 17:45:17 -0300 | [diff] [blame] | 3 | * |
| 4 | * Copyright (c) 2003-2008 Fabrice Bellard |
| 5 | * Copyright (c) 2014 Red Hat Inc. |
| 6 | * |
| 7 | * Permission is hereby granted, free of charge, to any person obtaining a copy |
| 8 | * of this software and associated documentation files (the "Software"), to deal |
| 9 | * in the Software without restriction, including without limitation the rights |
| 10 | * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
| 11 | * copies of the Software, and to permit persons to whom the Software is |
| 12 | * furnished to do so, subject to the following conditions: |
| 13 | * |
| 14 | * The above copyright notice and this permission notice shall be included in |
| 15 | * all copies or substantial portions of the Software. |
| 16 | * |
| 17 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| 18 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| 19 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
| 20 | * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| 21 | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
| 22 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
| 23 | * THE SOFTWARE. |
| 24 | */ |
| 25 | |
Peter Maydell | d38ea87 | 2016-01-29 17:50:05 +0000 | [diff] [blame] | 26 | #include "qemu/osdep.h" |
Claudio Fontana | 940e43a | 2021-02-04 17:39:24 +0100 | [diff] [blame] | 27 | #include "qemu/accel.h" |
Eduardo Habkost | f6a1ef6 | 2014-09-26 17:45:30 -0300 | [diff] [blame] | 28 | #include "hw/boards.h" |
Claudio Fontana | b86f59c | 2021-02-04 17:39:25 +0100 | [diff] [blame] | 29 | #include "sysemu/cpus.h" |
Richard Henderson | cc37d98 | 2023-03-15 17:43:13 +0000 | [diff] [blame] | 30 | #include "qemu/error-report.h" |
Claudio Fontana | b86f59c | 2021-02-04 17:39:25 +0100 | [diff] [blame] | 31 | #include "accel-softmmu.h" |
Eduardo Habkost | a1a9cb0 | 2014-09-26 17:45:17 -0300 | [diff] [blame] | 32 | |
Paolo Bonzini | fc5cf82 | 2019-11-13 14:03:46 +0100 | [diff] [blame] | 33 | int accel_init_machine(AccelState *accel, MachineState *ms) |
Eduardo Habkost | d95c852 | 2014-09-26 17:45:28 -0300 | [diff] [blame] | 34 | { |
Paolo Bonzini | fc5cf82 | 2019-11-13 14:03:46 +0100 | [diff] [blame] | 35 | AccelClass *acc = ACCEL_GET_CLASS(accel); |
Eduardo Habkost | d95c852 | 2014-09-26 17:45:28 -0300 | [diff] [blame] | 36 | int ret; |
Eduardo Habkost | ac2da55 | 2014-09-26 17:45:31 -0300 | [diff] [blame] | 37 | ms->accelerator = accel; |
Eduardo Habkost | d95c852 | 2014-09-26 17:45:28 -0300 | [diff] [blame] | 38 | *(acc->allowed) = true; |
Eduardo Habkost | f6a1ef6 | 2014-09-26 17:45:30 -0300 | [diff] [blame] | 39 | ret = acc->init_machine(ms); |
Eduardo Habkost | d95c852 | 2014-09-26 17:45:28 -0300 | [diff] [blame] | 40 | if (ret < 0) { |
Eduardo Habkost | ac2da55 | 2014-09-26 17:45:31 -0300 | [diff] [blame] | 41 | ms->accelerator = NULL; |
Eduardo Habkost | d95c852 | 2014-09-26 17:45:28 -0300 | [diff] [blame] | 42 | *(acc->allowed) = false; |
Eduardo Habkost | ac2da55 | 2014-09-26 17:45:31 -0300 | [diff] [blame] | 43 | object_unref(OBJECT(accel)); |
Markus Armbruster | 79b9d4b | 2019-04-01 11:08:27 +0200 | [diff] [blame] | 44 | } else { |
| 45 | object_set_accelerator_compat_props(acc->compat_props); |
Eduardo Habkost | d95c852 | 2014-09-26 17:45:28 -0300 | [diff] [blame] | 46 | } |
| 47 | return ret; |
| 48 | } |
| 49 | |
Philippe Mathieu-Daudé | ce7cdeb | 2020-01-21 12:03:47 +0100 | [diff] [blame] | 50 | AccelState *current_accel(void) |
| 51 | { |
| 52 | return current_machine->accelerator; |
| 53 | } |
| 54 | |
Ian Jackson | 7a64c17 | 2018-03-09 12:02:50 +0000 | [diff] [blame] | 55 | void accel_setup_post(MachineState *ms) |
| 56 | { |
| 57 | AccelState *accel = ms->accelerator; |
| 58 | AccelClass *acc = ACCEL_GET_CLASS(accel); |
| 59 | if (acc->setup_post) { |
| 60 | acc->setup_post(ms, accel); |
| 61 | } |
| 62 | } |
Claudio Fontana | b86f59c | 2021-02-04 17:39:25 +0100 | [diff] [blame] | 63 | |
| 64 | /* initialize the arch-independent accel operation interfaces */ |
| 65 | void accel_init_ops_interfaces(AccelClass *ac) |
| 66 | { |
| 67 | const char *ac_name; |
| 68 | char *ops_name; |
Claudio Fontana | 5141e9a | 2022-09-29 11:30:35 +0200 | [diff] [blame] | 69 | ObjectClass *oc; |
Claudio Fontana | b86f59c | 2021-02-04 17:39:25 +0100 | [diff] [blame] | 70 | AccelOpsClass *ops; |
| 71 | |
| 72 | ac_name = object_class_get_name(OBJECT_CLASS(ac)); |
| 73 | g_assert(ac_name != NULL); |
| 74 | |
| 75 | ops_name = g_strdup_printf("%s" ACCEL_OPS_SUFFIX, ac_name); |
Gerd Hoffmann | f934907 | 2021-06-24 12:38:27 +0200 | [diff] [blame] | 76 | ops = ACCEL_OPS_CLASS(module_object_class_by_name(ops_name)); |
Claudio Fontana | 5141e9a | 2022-09-29 11:30:35 +0200 | [diff] [blame] | 77 | oc = module_object_class_by_name(ops_name); |
| 78 | if (!oc) { |
| 79 | error_report("fatal: could not load module for type '%s'", ops_name); |
| 80 | exit(1); |
| 81 | } |
Claudio Fontana | b86f59c | 2021-02-04 17:39:25 +0100 | [diff] [blame] | 82 | g_free(ops_name); |
Claudio Fontana | 5141e9a | 2022-09-29 11:30:35 +0200 | [diff] [blame] | 83 | ops = ACCEL_OPS_CLASS(oc); |
Claudio Fontana | b86f59c | 2021-02-04 17:39:25 +0100 | [diff] [blame] | 84 | /* |
| 85 | * all accelerators need to define ops, providing at least a mandatory |
| 86 | * non-NULL create_vcpu_thread operation. |
| 87 | */ |
| 88 | g_assert(ops != NULL); |
| 89 | if (ops->ops_init) { |
| 90 | ops->ops_init(ops); |
| 91 | } |
| 92 | cpus_register_accel(ops); |
| 93 | } |
| 94 | |
| 95 | static const TypeInfo accel_ops_type_info = { |
| 96 | .name = TYPE_ACCEL_OPS, |
| 97 | .parent = TYPE_OBJECT, |
| 98 | .abstract = true, |
| 99 | .class_size = sizeof(AccelOpsClass), |
| 100 | }; |
| 101 | |
| 102 | static void accel_softmmu_register_types(void) |
| 103 | { |
| 104 | type_register_static(&accel_ops_type_info); |
| 105 | } |
| 106 | type_init(accel_softmmu_register_types); |