triboard.h 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /*
  2. * Infineon TriBoard System emulation.
  3. *
  4. * Copyright (c) 2020 Andreas Konopik <andreas.konopik@efs-auto.de>
  5. * Copyright (c) 2020 David Brenken <david.brenken@efs-auto.de>
  6. *
  7. * This library is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Lesser General Public
  9. * License as published by the Free Software Foundation; either
  10. * version 2 of the License, or (at your option) any later version.
  11. *
  12. * This library is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public
  18. * License along with this library; if not, see <http://www.gnu.org/licenses/>.
  19. */
  20. #include "qapi/error.h"
  21. #include "hw/boards.h"
  22. #include "system/system.h"
  23. #include "exec/address-spaces.h"
  24. #include "qom/object.h"
  25. #include "hw/tricore/tc27x_soc.h"
  26. #define TYPE_TRIBOARD_MACHINE MACHINE_TYPE_NAME("triboard")
  27. typedef struct TriBoardMachineState TriBoardMachineState;
  28. typedef struct TriBoardMachineClass TriBoardMachineClass;
  29. DECLARE_OBJ_CHECKERS(TriBoardMachineState, TriBoardMachineClass,
  30. TRIBOARD_MACHINE, TYPE_TRIBOARD_MACHINE)
  31. struct TriBoardMachineState {
  32. MachineState parent;
  33. TC27XSoCState tc27x_soc;
  34. };
  35. struct TriBoardMachineClass {
  36. MachineClass parent_obj;
  37. const char *name;
  38. const char *desc;
  39. const char *soc_name;
  40. };