Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a7d2ffa8 authored by Treehugger Robot's avatar Treehugger Robot Committed by Gerrit Code Review
Browse files

Merge "Move DwarfCfaInfo::kTable from data.rel.ro to rodata"

parents bcede5f6 80aba549
Loading
Loading
Loading
Loading
+39 −39
Original line number Diff line number Diff line
@@ -204,7 +204,7 @@ template <typename AddressType>
bool DwarfCfa<AddressType>::LogInstruction(uint32_t indent, uint64_t cfa_offset, uint8_t op,
                                           uint64_t* cur_pc) {
  const auto* cfa = &DwarfCfaInfo::kTable[op];
  if (cfa->name == nullptr) {
  if (cfa->name[0] == '\0') {
    log(indent, "Illegal");
    log(indent, "Raw Data: 0x%02x", op);
    return true;
@@ -677,29 +677,29 @@ const DwarfCfaInfo::Info DwarfCfaInfo::kTable[64] = {
        {DW_EH_PE_uleb128, DW_EH_PE_block},
        {DWARF_DISPLAY_REGISTER, DWARF_DISPLAY_EVAL_BLOCK},
    },
    {nullptr, 0, 0, {}, {}},  // 0x17 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x18 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x19 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x1a illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x1b illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x1c DW_CFA_lo_user (Treat as illegal)
    {nullptr, 0, 0, {}, {}},  // 0x1d illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x1e illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x1f illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x20 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x21 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x22 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x23 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x24 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x25 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x26 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x27 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x28 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x29 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x2a illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x2b illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x2c illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x2d DW_CFA_GNU_window_save (Treat as illegal)
    {"", 0, 0, {}, {}},  // 0x17 illegal cfa
    {"", 0, 0, {}, {}},  // 0x18 illegal cfa
    {"", 0, 0, {}, {}},  // 0x19 illegal cfa
    {"", 0, 0, {}, {}},  // 0x1a illegal cfa
    {"", 0, 0, {}, {}},  // 0x1b illegal cfa
    {"", 0, 0, {}, {}},  // 0x1c DW_CFA_lo_user (Treat as illegal)
    {"", 0, 0, {}, {}},  // 0x1d illegal cfa
    {"", 0, 0, {}, {}},  // 0x1e illegal cfa
    {"", 0, 0, {}, {}},  // 0x1f illegal cfa
    {"", 0, 0, {}, {}},  // 0x20 illegal cfa
    {"", 0, 0, {}, {}},  // 0x21 illegal cfa
    {"", 0, 0, {}, {}},  // 0x22 illegal cfa
    {"", 0, 0, {}, {}},  // 0x23 illegal cfa
    {"", 0, 0, {}, {}},  // 0x24 illegal cfa
    {"", 0, 0, {}, {}},  // 0x25 illegal cfa
    {"", 0, 0, {}, {}},  // 0x26 illegal cfa
    {"", 0, 0, {}, {}},  // 0x27 illegal cfa
    {"", 0, 0, {}, {}},  // 0x28 illegal cfa
    {"", 0, 0, {}, {}},  // 0x29 illegal cfa
    {"", 0, 0, {}, {}},  // 0x2a illegal cfa
    {"", 0, 0, {}, {}},  // 0x2b illegal cfa
    {"", 0, 0, {}, {}},  // 0x2c illegal cfa
    {"", 0, 0, {}, {}},  // 0x2d DW_CFA_GNU_window_save (Treat as illegal)
    {
        "DW_CFA_GNU_args_size",  // 0x2e DW_CFA_GNU_args_size
        2,
@@ -714,21 +714,21 @@ const DwarfCfaInfo::Info DwarfCfaInfo::kTable[64] = {
        {DW_EH_PE_uleb128, DW_EH_PE_uleb128},
        {DWARF_DISPLAY_REGISTER, DWARF_DISPLAY_NUMBER},
    },
    {nullptr, 0, 0, {}, {}},  // 0x31 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x32 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x33 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x34 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x35 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x36 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x37 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x38 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x39 illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x3a illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x3b illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x3c illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x3d illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x3e illegal cfa
    {nullptr, 0, 0, {}, {}},  // 0x3f DW_CFA_hi_user (Treat as illegal)
    {"", 0, 0, {}, {}},  // 0x31 illegal cfa
    {"", 0, 0, {}, {}},  // 0x32 illegal cfa
    {"", 0, 0, {}, {}},  // 0x33 illegal cfa
    {"", 0, 0, {}, {}},  // 0x34 illegal cfa
    {"", 0, 0, {}, {}},  // 0x35 illegal cfa
    {"", 0, 0, {}, {}},  // 0x36 illegal cfa
    {"", 0, 0, {}, {}},  // 0x37 illegal cfa
    {"", 0, 0, {}, {}},  // 0x38 illegal cfa
    {"", 0, 0, {}, {}},  // 0x39 illegal cfa
    {"", 0, 0, {}, {}},  // 0x3a illegal cfa
    {"", 0, 0, {}, {}},  // 0x3b illegal cfa
    {"", 0, 0, {}, {}},  // 0x3c illegal cfa
    {"", 0, 0, {}, {}},  // 0x3d illegal cfa
    {"", 0, 0, {}, {}},  // 0x3e illegal cfa
    {"", 0, 0, {}, {}},  // 0x3f DW_CFA_hi_user (Treat as illegal)
};

// Explicitly instantiate DwarfCfa.
+8 −1
Original line number Diff line number Diff line
@@ -49,7 +49,14 @@ class DwarfCfaInfo {
  };

  struct Info {
    const char* name;
    // It may seem cleaner to just change the type of 'name' to 'const char *'.
    // However, having a pointer here would require relocation at runtime,
    // causing 'kTable' to be placed in data.rel.ro section instead of rodata
    // section, adding memory pressure to the system.  Note that this is only
    // safe because this is only used in C++ code.  C++ standard, unlike C
    // standard, mandates the array size to be large enough to hold the NULL
    // terminator when initialized with a string literal.
    const char name[36];
    uint8_t supported_version;
    uint8_t num_operands;
    uint8_t operands[2];