| 
									
										
										
										
											2012-04-11 01:22:08 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * QEMU LatticeMico32 CPU | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2012 SUSE LINUX Products GmbH | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This library is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License as published by the Free Software Foundation; either | 
					
						
							|  |  |  |  * version 2.1 of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This library is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
					
						
							|  |  |  |  * Lesser General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License along with this library; if not, see | 
					
						
							|  |  |  |  * <http://www.gnu.org/licenses/lgpl-2.1.html>
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-26 18:16:57 +00:00
										 |  |  | #include "qemu/osdep.h"
 | 
					
						
							| 
									
										
											  
											
												include/qemu/osdep.h: Don't include qapi/error.h
Commit 57cb38b included qapi/error.h into qemu/osdep.h to get the
Error typedef.  Since then, we've moved to include qemu/osdep.h
everywhere.  Its file comment explains: "To avoid getting into
possible circular include dependencies, this file should not include
any other QEMU headers, with the exceptions of config-host.h,
compiler.h, os-posix.h and os-win32.h, all of which are doing a
similar job to this file and are under similar constraints."
qapi/error.h doesn't do a similar job, and it doesn't adhere to
similar constraints: it includes qapi-types.h.  That's in excess of
100KiB of crap most .c files don't actually need.
Add the typedef to qemu/typedefs.h, and include that instead of
qapi/error.h.  Include qapi/error.h in .c files that need it and don't
get it now.  Include qapi-types.h in qom/object.h for uint16List.
Update scripts/clean-includes accordingly.  Update it further to match
reality: replace config.h by config-target.h, add sysemu/os-posix.h,
sysemu/os-win32.h.  Update the list of includes in the qemu/osdep.h
comment quoted above similarly.
This reduces the number of objects depending on qapi/error.h from "all
of them" to less than a third.  Unfortunately, the number depending on
qapi-types.h shrinks only a little.  More work is needed for that one.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
[Fix compilation without the spice devel packages. - Paolo]
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
											
										 
											2016-03-14 09:01:28 +01:00
										 |  |  | #include "qapi/error.h"
 | 
					
						
							| 
									
										
										
										
											2012-05-06 12:40:55 +02:00
										 |  |  | #include "cpu.h"
 | 
					
						
							| 
									
										
										
										
											2012-04-11 01:22:08 +02:00
										 |  |  | #include "qemu-common.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-21 19:09:18 +02:00
										 |  |  | static void lm32_cpu_set_pc(CPUState *cs, vaddr value) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     LM32CPU *cpu = LM32_CPU(cs); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cpu->env.pc = value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-17 18:33:16 +02:00
										 |  |  | static void lm32_cpu_list_entry(gpointer data, gpointer user_data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ObjectClass *oc = data; | 
					
						
							|  |  |  |     CPUListState *s = user_data; | 
					
						
							|  |  |  |     const char *typename = object_class_get_name(oc); | 
					
						
							|  |  |  |     char *name; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-05 15:50:42 +02:00
										 |  |  |     name = g_strndup(typename, strlen(typename) - strlen(LM32_CPU_TYPE_SUFFIX)); | 
					
						
							| 
									
										
										
										
											2013-09-17 18:33:16 +02:00
										 |  |  |     (*s->cpu_fprintf)(s->file, "  %s\n", name); | 
					
						
							|  |  |  |     g_free(name); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void lm32_cpu_list(FILE *f, fprintf_function cpu_fprintf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     CPUListState s = { | 
					
						
							|  |  |  |         .file = f, | 
					
						
							|  |  |  |         .cpu_fprintf = cpu_fprintf, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     GSList *list; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-03 08:33:10 +01:00
										 |  |  |     list = object_class_get_list_sorted(TYPE_LM32_CPU, false); | 
					
						
							| 
									
										
										
										
											2013-09-17 18:33:16 +02:00
										 |  |  |     (*cpu_fprintf)(f, "Available CPUs:\n"); | 
					
						
							|  |  |  |     g_slist_foreach(list, lm32_cpu_list_entry, &s); | 
					
						
							|  |  |  |     g_slist_free(list); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void lm32_cpu_init_cfg_reg(LM32CPU *cpu) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     CPULM32State *env = &cpu->env; | 
					
						
							|  |  |  |     uint32_t cfg = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (cpu->features & LM32_FEATURE_MULTIPLY) { | 
					
						
							|  |  |  |         cfg |= CFG_M; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (cpu->features & LM32_FEATURE_DIVIDE) { | 
					
						
							|  |  |  |         cfg |= CFG_D; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (cpu->features & LM32_FEATURE_SHIFT) { | 
					
						
							|  |  |  |         cfg |= CFG_S; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (cpu->features & LM32_FEATURE_SIGN_EXTEND) { | 
					
						
							|  |  |  |         cfg |= CFG_X; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (cpu->features & LM32_FEATURE_I_CACHE) { | 
					
						
							|  |  |  |         cfg |= CFG_IC; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (cpu->features & LM32_FEATURE_D_CACHE) { | 
					
						
							|  |  |  |         cfg |= CFG_DC; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (cpu->features & LM32_FEATURE_CYCLE_COUNT) { | 
					
						
							|  |  |  |         cfg |= CFG_CC; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cfg |= (cpu->num_interrupts << CFG_INT_SHIFT); | 
					
						
							|  |  |  |     cfg |= (cpu->num_breakpoints << CFG_BP_SHIFT); | 
					
						
							|  |  |  |     cfg |= (cpu->num_watchpoints << CFG_WP_SHIFT); | 
					
						
							|  |  |  |     cfg |= (cpu->revision << CFG_REV_SHIFT); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     env->cfg = cfg; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-25 18:53:55 +02:00
										 |  |  | static bool lm32_cpu_has_work(CPUState *cs) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return cs->interrupt_request & CPU_INTERRUPT_HARD; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-11 01:22:08 +02:00
										 |  |  | /* CPUClass::reset() */ | 
					
						
							|  |  |  | static void lm32_cpu_reset(CPUState *s) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     LM32CPU *cpu = LM32_CPU(s); | 
					
						
							|  |  |  |     LM32CPUClass *lcc = LM32_CPU_GET_CLASS(cpu); | 
					
						
							|  |  |  |     CPULM32State *env = &cpu->env; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lcc->parent_reset(s); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-11 01:37:45 +02:00
										 |  |  |     /* reset cpu state */ | 
					
						
							| 
									
										
										
										
											2016-11-14 14:19:17 +00:00
										 |  |  |     memset(env, 0, offsetof(CPULM32State, end_reset_fields)); | 
					
						
							| 
									
										
										
										
											2013-02-26 19:51:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-17 18:33:16 +02:00
										 |  |  |     lm32_cpu_init_cfg_reg(cpu); | 
					
						
							| 
									
										
										
										
											2012-04-11 01:22:08 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-11 19:00:02 -07:00
										 |  |  | static void lm32_cpu_disas_set_info(CPUState *cpu, disassemble_info *info) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     info->mach = bfd_mach_lm32; | 
					
						
							|  |  |  |     info->print_insn = print_insn_lm32; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-16 03:31:27 +01:00
										 |  |  | static void lm32_cpu_realizefn(DeviceState *dev, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-07-27 02:53:25 +02:00
										 |  |  |     CPUState *cs = CPU(dev); | 
					
						
							| 
									
										
										
										
											2013-01-16 03:31:27 +01:00
										 |  |  |     LM32CPUClass *lcc = LM32_CPU_GET_CLASS(dev); | 
					
						
							| 
									
										
										
										
											2016-10-20 13:26:03 +02:00
										 |  |  |     Error *local_err = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cpu_exec_realizefn(cs, &local_err); | 
					
						
							|  |  |  |     if (local_err != NULL) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-01-16 03:31:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-27 02:53:25 +02:00
										 |  |  |     cpu_reset(cs); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     qemu_init_vcpu(cs); | 
					
						
							| 
									
										
										
										
											2013-01-16 03:31:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     lcc->parent_realize(dev, errp); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-11 01:33:33 +02:00
										 |  |  | static void lm32_cpu_initfn(Object *obj) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-01-17 12:13:41 +01:00
										 |  |  |     CPUState *cs = CPU(obj); | 
					
						
							| 
									
										
										
										
											2012-04-11 01:33:33 +02:00
										 |  |  |     LM32CPU *cpu = LM32_CPU(obj); | 
					
						
							|  |  |  |     CPULM32State *env = &cpu->env; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-17 12:13:41 +01:00
										 |  |  |     cs->env_ptr = env; | 
					
						
							| 
									
										
										
										
											2012-04-11 01:33:33 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     env->flags = 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-17 18:33:16 +02:00
										 |  |  | static void lm32_basic_cpu_initfn(Object *obj) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     LM32CPU *cpu = LM32_CPU(obj); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cpu->revision = 3; | 
					
						
							|  |  |  |     cpu->num_interrupts = 32; | 
					
						
							|  |  |  |     cpu->num_breakpoints = 4; | 
					
						
							|  |  |  |     cpu->num_watchpoints = 4; | 
					
						
							|  |  |  |     cpu->features = LM32_FEATURE_SHIFT | 
					
						
							|  |  |  |                   | LM32_FEATURE_SIGN_EXTEND | 
					
						
							|  |  |  |                   | LM32_FEATURE_CYCLE_COUNT; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void lm32_standard_cpu_initfn(Object *obj) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     LM32CPU *cpu = LM32_CPU(obj); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cpu->revision = 3; | 
					
						
							|  |  |  |     cpu->num_interrupts = 32; | 
					
						
							|  |  |  |     cpu->num_breakpoints = 4; | 
					
						
							|  |  |  |     cpu->num_watchpoints = 4; | 
					
						
							|  |  |  |     cpu->features = LM32_FEATURE_MULTIPLY | 
					
						
							|  |  |  |                   | LM32_FEATURE_DIVIDE | 
					
						
							|  |  |  |                   | LM32_FEATURE_SHIFT | 
					
						
							|  |  |  |                   | LM32_FEATURE_SIGN_EXTEND | 
					
						
							|  |  |  |                   | LM32_FEATURE_I_CACHE | 
					
						
							|  |  |  |                   | LM32_FEATURE_CYCLE_COUNT; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void lm32_full_cpu_initfn(Object *obj) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     LM32CPU *cpu = LM32_CPU(obj); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cpu->revision = 3; | 
					
						
							|  |  |  |     cpu->num_interrupts = 32; | 
					
						
							|  |  |  |     cpu->num_breakpoints = 4; | 
					
						
							|  |  |  |     cpu->num_watchpoints = 4; | 
					
						
							|  |  |  |     cpu->features = LM32_FEATURE_MULTIPLY | 
					
						
							|  |  |  |                   | LM32_FEATURE_DIVIDE | 
					
						
							|  |  |  |                   | LM32_FEATURE_SHIFT | 
					
						
							|  |  |  |                   | LM32_FEATURE_SIGN_EXTEND | 
					
						
							|  |  |  |                   | LM32_FEATURE_I_CACHE | 
					
						
							|  |  |  |                   | LM32_FEATURE_D_CACHE | 
					
						
							|  |  |  |                   | LM32_FEATURE_CYCLE_COUNT; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static ObjectClass *lm32_cpu_class_by_name(const char *cpu_model) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ObjectClass *oc; | 
					
						
							|  |  |  |     char *typename; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-05 15:50:42 +02:00
										 |  |  |     typename = g_strdup_printf(LM32_CPU_TYPE_NAME("%s"), cpu_model); | 
					
						
							| 
									
										
										
										
											2013-09-17 18:33:16 +02:00
										 |  |  |     oc = object_class_by_name(typename); | 
					
						
							|  |  |  |     g_free(typename); | 
					
						
							|  |  |  |     if (oc != NULL && (!object_class_dynamic_cast(oc, TYPE_LM32_CPU) || | 
					
						
							|  |  |  |                        object_class_is_abstract(oc))) { | 
					
						
							|  |  |  |         oc = NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return oc; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-11 01:22:08 +02:00
										 |  |  | static void lm32_cpu_class_init(ObjectClass *oc, void *data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     LM32CPUClass *lcc = LM32_CPU_CLASS(oc); | 
					
						
							|  |  |  |     CPUClass *cc = CPU_CLASS(oc); | 
					
						
							| 
									
										
										
										
											2013-01-16 03:31:27 +01:00
										 |  |  |     DeviceClass *dc = DEVICE_CLASS(oc); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-13 23:04:12 -03:00
										 |  |  |     device_class_set_parent_realize(dc, lm32_cpu_realizefn, | 
					
						
							|  |  |  |                                     &lcc->parent_realize); | 
					
						
							| 
									
										
										
										
											2012-04-11 01:22:08 +02:00
										 |  |  |     lcc->parent_reset = cc->reset; | 
					
						
							|  |  |  |     cc->reset = lm32_cpu_reset; | 
					
						
							| 
									
										
										
										
											2013-02-02 10:57:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-17 18:33:16 +02:00
										 |  |  |     cc->class_by_name = lm32_cpu_class_by_name; | 
					
						
							| 
									
										
										
										
											2013-08-25 18:53:55 +02:00
										 |  |  |     cc->has_work = lm32_cpu_has_work; | 
					
						
							| 
									
										
										
										
											2013-02-02 10:57:51 +01:00
										 |  |  |     cc->do_interrupt = lm32_cpu_do_interrupt; | 
					
						
							| 
									
										
										
										
											2014-09-13 09:45:31 -07:00
										 |  |  |     cc->cpu_exec_interrupt = lm32_cpu_exec_interrupt; | 
					
						
							| 
									
										
										
										
											2013-05-27 01:33:50 +02:00
										 |  |  |     cc->dump_state = lm32_cpu_dump_state; | 
					
						
							| 
									
										
										
										
											2013-06-21 19:09:18 +02:00
										 |  |  |     cc->set_pc = lm32_cpu_set_pc; | 
					
						
							| 
									
										
										
										
											2013-06-29 04:18:45 +02:00
										 |  |  |     cc->gdb_read_register = lm32_cpu_gdb_read_register; | 
					
						
							|  |  |  |     cc->gdb_write_register = lm32_cpu_gdb_write_register; | 
					
						
							| 
									
										
										
										
											2013-08-26 03:01:33 +02:00
										 |  |  | #ifdef CONFIG_USER_ONLY
 | 
					
						
							|  |  |  |     cc->handle_mmu_fault = lm32_cpu_handle_mmu_fault; | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2013-06-29 18:55:54 +02:00
										 |  |  |     cc->get_phys_page_debug = lm32_cpu_get_phys_page_debug; | 
					
						
							|  |  |  |     cc->vmsd = &vmstate_lm32_cpu; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-06-28 23:18:47 +02:00
										 |  |  |     cc->gdb_num_core_regs = 32 + 7; | 
					
						
							| 
									
										
										
										
											2014-09-12 19:04:17 +01:00
										 |  |  |     cc->gdb_stop_before_watchpoint = true; | 
					
						
							| 
									
										
										
										
											2014-09-12 14:06:48 +01:00
										 |  |  |     cc->debug_excp_handler = lm32_debug_excp_handler; | 
					
						
							| 
									
										
										
										
											2015-07-11 19:00:02 -07:00
										 |  |  |     cc->disas_set_info = lm32_cpu_disas_set_info; | 
					
						
							| 
									
										
										
										
											2017-10-15 19:02:42 -07:00
										 |  |  |     cc->tcg_initialize = lm32_translate_init; | 
					
						
							| 
									
										
										
										
											2012-04-11 01:22:08 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-05 15:50:42 +02:00
										 |  |  | #define DEFINE_LM32_CPU_TYPE(cpu_model, initfn) \
 | 
					
						
							|  |  |  |     { \ | 
					
						
							|  |  |  |         .parent = TYPE_LM32_CPU, \ | 
					
						
							|  |  |  |         .name = LM32_CPU_TYPE_NAME(cpu_model), \ | 
					
						
							|  |  |  |         .instance_init = initfn, \ | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-17 18:33:16 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-05 15:50:42 +02:00
										 |  |  | static const TypeInfo lm32_cpus_type_infos[] = { | 
					
						
							|  |  |  |     { /* base class should be registered first */ | 
					
						
							|  |  |  |          .name = TYPE_LM32_CPU, | 
					
						
							|  |  |  |          .parent = TYPE_CPU, | 
					
						
							|  |  |  |          .instance_size = sizeof(LM32CPU), | 
					
						
							|  |  |  |          .instance_init = lm32_cpu_initfn, | 
					
						
							|  |  |  |          .abstract = true, | 
					
						
							|  |  |  |          .class_size = sizeof(LM32CPUClass), | 
					
						
							|  |  |  |          .class_init = lm32_cpu_class_init, | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     DEFINE_LM32_CPU_TYPE("lm32-basic", lm32_basic_cpu_initfn), | 
					
						
							|  |  |  |     DEFINE_LM32_CPU_TYPE("lm32-standard", lm32_standard_cpu_initfn), | 
					
						
							|  |  |  |     DEFINE_LM32_CPU_TYPE("lm32-full", lm32_full_cpu_initfn), | 
					
						
							| 
									
										
										
										
											2012-04-11 01:22:08 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-05 15:50:42 +02:00
										 |  |  | DEFINE_TYPES(lm32_cpus_type_infos) |