These are optional. .init doesn't distinguish types of data like this, and
livepatches don't necesserily have any .rodata either.
No functional change.
Signed-off-by: Andrew Cooper <andrew.cooper3@citrix.com>
Reviewed-by: Roger Pau Monné <roger.pau@citrix.com>
Reviewed-by: Ross Lagerwall <ross.lagerwall@citrix.com>
master commit:
ef969144a425e39f5b214a875b5713d0ea8575fb
master date: 2024-03-07 14:24:42 +0000
region->text_start = payload->text_addr;
region->text_end = payload->text_addr + payload->text_size;
+ if ( payload->ro_size )
+ {
+ region->rodata_start = payload->ro_addr;
+ region->rodata_end = payload->ro_addr + payload->ro_size;
+ }
+
/* Optional sections. */
for ( i = 0; i < BUGFRAME_NR; i++ )
{
.list = LIST_HEAD_INIT(core.list),
.text_start = _stext,
.text_end = _etext,
+ .rodata_start = _srodata,
+ .rodata_end = _erodata,
};
/* Becomes irrelevant when __init sections are cleared. */
const void *text_start; /* .text virtual address start. */
const void *text_end; /* .text virtual address end. */
+ const void *rodata_start; /* .rodata virtual address start (optional). */
+ const void *rodata_end; /* .rodata virtual address end. */
+
/* If this is NULL the default lookup mechanism is used. */
symbols_lookup_t *symbols_lookup;