/* GNU/Linux/aarch64 specific target description, for the remote server for GDB. Copyright (C) 2017-2023 Free Software Foundation, Inc. This file is part of GDB. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program 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 General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include "server.h" #include "linux-aarch64-tdesc.h" #include "tdesc.h" #include "arch/aarch64.h" #include "linux-aarch32-low.h" #include #include /* All possible aarch64 target descriptors. */ static std::unordered_map tdesc_aarch64_map; static std::vector expedited_registers; /* Create the aarch64 target description. */ const target_desc * aarch64_linux_read_description (const aarch64_features &features) { if (features.vq > AARCH64_MAX_SVE_VQ) error (_("VQ is %" PRIu64 ", maximum supported value is %d"), features.vq, AARCH64_MAX_SVE_VQ); if (features.svq > AARCH64_MAX_SVE_VQ) error (_("Streaming svq is %" PRIu8 ", maximum supported value is %d"), features.svq, AARCH64_MAX_SVE_VQ); struct target_desc *tdesc = tdesc_aarch64_map[features]; if (tdesc == NULL) { tdesc = aarch64_create_target_description (features); expedited_registers.clear (); /* Configure the expedited registers. By default we include x29, sp and pc. */ expedited_registers.push_back ("x29"); expedited_registers.push_back ("sp"); expedited_registers.push_back ("pc"); if (features.vq > 0) expedited_registers.push_back ("vg"); if (features.svq > 0) expedited_registers.push_back ("svg"); expedited_registers.push_back (nullptr); init_target_desc (tdesc, (const char **) expedited_registers.data ()); tdesc_aarch64_map[features] = tdesc; } return tdesc; }