|
@@ -3907,8 +3907,23 @@ implementation
|
|
end;
|
|
end;
|
|
ObjSec.ObjRelocations.Add(TWasmObjRelocation.CreateTypeIndex(RelocOffset-BaseSectionOffset,RelocIndex));
|
|
ObjSec.ObjRelocations.Add(TWasmObjRelocation.CreateTypeIndex(RelocOffset-BaseSectionOffset,RelocIndex));
|
|
end;
|
|
end;
|
|
|
|
+ R_WASM_FUNCTION_OFFSET_I32:
|
|
|
|
+ begin
|
|
|
|
+ if RelocIndex>high(SymbolTable) then
|
|
|
|
+ begin
|
|
|
|
+ InputError('Symbol index in relocation too high');
|
|
|
|
+ exit;
|
|
|
|
+ end;
|
|
|
|
+ if Assigned(SymbolTable[RelocIndex].ObjSym) then
|
|
|
|
+ begin
|
|
|
|
+ ObjReloc:=TWasmObjRelocation.CreateSymbol(RelocOffset-BaseSectionOffset,SymbolTable[RelocIndex].ObjSym,RELOC_ABSOLUTE);
|
|
|
|
+ ObjReloc.Addend:=RelocAddend;
|
|
|
|
+ ObjSec.ObjRelocations.Add(ObjReloc);
|
|
|
|
+ end
|
|
|
|
+ else
|
|
|
|
+ Writeln('Warning! No object symbol created for ', SymbolTable[RelocIndex].SymName);
|
|
|
|
+ end;
|
|
R_WASM_SECTION_OFFSET_I32,
|
|
R_WASM_SECTION_OFFSET_I32,
|
|
- R_WASM_FUNCTION_OFFSET_I32,
|
|
|
|
R_WASM_GLOBAL_INDEX_LEB,
|
|
R_WASM_GLOBAL_INDEX_LEB,
|
|
R_WASM_TAG_INDEX_LEB:
|
|
R_WASM_TAG_INDEX_LEB:
|
|
{TODO};
|
|
{TODO};
|