2
0

dxeload.pp 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. {
  2. $Id$
  3. This file is part of the Free Pascal run time library.
  4. Copyright (c) 1999-2000 by Pierre Muller,
  5. member of the Free Pascal development team.
  6. Unit to Load DXE files for Go32V2
  7. See the file COPYING.FPC, included in this distribution,
  8. for details about the copyright.
  9. This program is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  12. **********************************************************************
  13. }
  14. Unit dxeload;
  15. interface
  16. const
  17. DXE_MAGIC = $31455844;
  18. type
  19. dxe_header = record
  20. magic,
  21. symbol_offset,
  22. element_size,
  23. nrelocs : longint;
  24. end;
  25. function dxe_load(filename : string) : pointer;
  26. implementation
  27. function dxe_load(filename : string) : pointer;
  28. {
  29. Copyright (C) 1995 Charles Sandmann ([email protected])
  30. translated to Free Pascal by Pierre Muller
  31. }
  32. type
  33. { to avoid range check problems }
  34. pointer_array = array[0..maxlongint] of pointer;
  35. tpa = ^pointer_array;
  36. plongint = ^longint;
  37. ppointer = ^pointer;
  38. var
  39. dh : dxe_header;
  40. data : pchar;
  41. f : file;
  42. relocs : tpa;
  43. i : longint;
  44. addr : plongint;
  45. begin
  46. dxe_load:=nil;
  47. { open the file }
  48. assign(f,filename);
  49. {$I-}
  50. reset(f,1);
  51. {$I+}
  52. { quit if no file !! }
  53. if ioresult<>0 then
  54. exit;
  55. { load the header }
  56. blockread(f,@dh,sizeof(dxe_header),i);
  57. if (i<>sizeof(dxe_header)) or (dh.magic<>DXE_MAGIC) then
  58. begin
  59. close(f);
  60. exit;
  61. end;
  62. { get memory for code }
  63. getmem(data,dh.element_size);
  64. if data=nil then
  65. exit;
  66. { get memory for relocations }
  67. getmem(relocs,dh.nrelocs*sizeof(pointer));
  68. if relocs=nil then
  69. begin
  70. freemem(data,dh.element_size);
  71. exit;
  72. end;
  73. { copy code }
  74. blockread(f,data^,dh.element_size);
  75. blockread(f,relocs^,dh.nrelocs*sizeof(pointer));
  76. close(f);
  77. { relocate internal references }
  78. for i:=0 to dh.nrelocs-1 do
  79. begin
  80. cardinal(addr):=cardinal(data)+cardinal(relocs^[i]);
  81. addr^:=addr^+pointer(data);
  82. end;
  83. dxe_load:=pointer( dh.symbol_offset + cardinal(data));
  84. end;
  85. end.
  86. {
  87. $Log$
  88. Revision 1.4 2000-02-09 16:59:28 peter
  89. * truncated log
  90. Revision 1.3 2000/01/07 16:41:31 daniel
  91. * copyright 2000
  92. Revision 1.2 2000/01/07 16:32:23 daniel
  93. * copyright 2000 added
  94. }