z80.inc 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349
  1. {
  2. This file is part of the Free Pascal run time library.
  3. Copyright (c) 2017 by the Free Pascal development team.
  4. Processor dependent implementation for the system unit for
  5. Z80
  6. See the file COPYING.FPC, included in this distribution,
  7. for details about the copyright.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  11. **********************************************************************}
  12. var
  13. z80_save_hl: Word; public name 'FPC_Z80_SAVE_HL';
  14. procedure fpc_cpuinit;{$ifdef SYSTEMINLINE}inline;{$endif}
  15. begin
  16. end;
  17. {$define FPC_SYSTEM_HAS_MOVE}
  18. procedure Move(const source;var dest;count:SizeInt);assembler;[public, alias: 'FPC_MOVE'];
  19. label
  20. skip, forward_move;
  21. asm
  22. ld c, (count)
  23. ld b, (count+1)
  24. bit 7, b
  25. jp NZ, skip
  26. ld a, b
  27. or a, c
  28. jp Z, skip
  29. ld l, (source)
  30. ld h, (source+1)
  31. ld e, (dest)
  32. ld d, (dest+1)
  33. ld a, d
  34. cp a, h
  35. jp C, forward_move
  36. ld a, e
  37. cp a, l
  38. jp C, forward_move
  39. { backward move }
  40. add hl, bc
  41. dec hl
  42. ex de, hl
  43. add hl, bc
  44. dec hl
  45. ex de, hl
  46. lddr
  47. jp skip
  48. forward_move:
  49. ldir
  50. skip:
  51. end;
  52. {$define FPC_SYSTEM_HAS_FILLCHAR}
  53. Procedure FillChar(var x;count:SizeInt;value:byte);assembler;
  54. label
  55. skip, loop;
  56. asm
  57. ld c, (count)
  58. ld b, (count+1)
  59. bit 7, b
  60. jp NZ, skip
  61. ld a, b
  62. or a, c
  63. jp Z, skip
  64. ld e, (value)
  65. ld a, 0
  66. ld l, (x)
  67. ld h, (x+1)
  68. loop:
  69. ld (hl), e
  70. inc hl
  71. dec bc
  72. cp a, c
  73. jp NZ, loop
  74. cp a, b
  75. jp NZ, loop
  76. skip:
  77. end;
  78. {$IFNDEF INTERNAL_BACKTRACE}
  79. {$define FPC_SYSTEM_HAS_GET_FRAME}
  80. function get_frame:pointer;assembler;nostackframe;
  81. asm
  82. push ix
  83. pop hl
  84. end;
  85. {$ENDIF not INTERNAL_BACKTRACE}
  86. {$define FPC_SYSTEM_HAS_GET_CALLER_ADDR}
  87. function get_caller_addr(framebp:pointer;addr:pointer=nil):pointer;assembler;
  88. label
  89. framebp_null;
  90. asm
  91. ld l, (framebp)
  92. ld h, (framebp+1)
  93. ld a, l
  94. or a, h
  95. jp Z, framebp_null
  96. inc hl
  97. inc hl
  98. ld e, (hl)
  99. inc hl
  100. ld d, (hl)
  101. ex de, hl
  102. framebp_null:
  103. end;
  104. {$define FPC_SYSTEM_HAS_GET_CALLER_FRAME}
  105. function get_caller_frame(framebp:pointer;addr:pointer=nil):pointer;assembler;
  106. label
  107. framebp_null;
  108. asm
  109. ld l, (framebp)
  110. ld h, (framebp+1)
  111. ld a, l
  112. or a, h
  113. jp Z, framebp_null
  114. ld e, (hl)
  115. inc hl
  116. ld d, (hl)
  117. ex de, hl
  118. framebp_null:
  119. end;
  120. {$define FPC_SYSTEM_HAS_SPTR}
  121. Function Sptr : pointer;assembler;nostackframe;
  122. asm
  123. ld hl, 0
  124. add hl, sp
  125. end;
  126. function InterLockedDecrement (var Target: longint) : longint;
  127. var
  128. temp_sreg : byte;
  129. begin
  130. { block interrupts }
  131. asm
  132. di
  133. end;
  134. dec(Target);
  135. Result:=Target;
  136. { release interrupts }
  137. asm
  138. ei
  139. end;
  140. end;
  141. function InterLockedIncrement (var Target: longint) : longint;
  142. var
  143. temp_sreg : byte;
  144. begin
  145. { block interrupts }
  146. asm
  147. di
  148. end;
  149. inc(Target);
  150. Result:=Target;
  151. { release interrupts }
  152. asm
  153. ei
  154. end;
  155. end;
  156. function InterLockedExchange (var Target: longint;Source : longint) : longint;
  157. var
  158. temp_sreg : byte;
  159. begin
  160. { block interrupts }
  161. asm
  162. di
  163. end;
  164. Result:=Target;
  165. Target:=Source;
  166. { release interrupts }
  167. asm
  168. ei
  169. end;
  170. end;
  171. function InterlockedCompareExchange(var Target: longint; NewValue: longint; Comperand: longint): longint;
  172. var
  173. temp_sreg : byte;
  174. begin
  175. { block interrupts }
  176. asm
  177. di
  178. end;
  179. Result:=Target;
  180. if Target=Comperand then
  181. Target:=NewValue;
  182. { release interrupts }
  183. asm
  184. ei
  185. end;
  186. end;
  187. function InterLockedExchangeAdd (var Target: longint;Source : longint) : longint;
  188. var
  189. temp_sreg : byte;
  190. begin
  191. { block interrupts }
  192. asm
  193. di
  194. end;
  195. Result:=Target;
  196. inc(Target,Source);
  197. { release interrupts }
  198. asm
  199. ei
  200. end;
  201. end;
  202. function InterLockedDecrement (var Target: smallint) : smallint;
  203. var
  204. temp_sreg : byte;
  205. begin
  206. { block interrupts }
  207. asm
  208. di
  209. end;
  210. dec(Target);
  211. Result:=Target;
  212. { release interrupts }
  213. asm
  214. ei
  215. end;
  216. end;
  217. function InterLockedIncrement (var Target: smallint) : smallint;
  218. var
  219. temp_sreg : byte;
  220. begin
  221. { block interrupts }
  222. asm
  223. di
  224. end;
  225. inc(Target);
  226. Result:=Target;
  227. { release interrupts }
  228. asm
  229. ei
  230. end;
  231. end;
  232. function InterLockedExchange (var Target: smallint;Source : smallint) : smallint;
  233. var
  234. temp_sreg : byte;
  235. begin
  236. { block interrupts }
  237. asm
  238. di
  239. end;
  240. Result:=Target;
  241. Target:=Source;
  242. { release interrupts }
  243. asm
  244. ei
  245. end;
  246. end;
  247. function InterlockedCompareExchange(var Target: smallint; NewValue: smallint; Comperand: smallint): smallint;
  248. var
  249. temp_sreg : byte;
  250. begin
  251. { block interrupts }
  252. asm
  253. di
  254. end;
  255. Result:=Target;
  256. if Target=Comperand then
  257. Target:=NewValue;
  258. { release interrupts }
  259. asm
  260. ei
  261. end;
  262. end;
  263. function InterLockedExchangeAdd (var Target: smallint;Source : smallint) : smallint;
  264. var
  265. temp_sreg : byte;
  266. begin
  267. { block interrupts }
  268. asm
  269. di
  270. end;
  271. Result:=Target;
  272. inc(Target,Source);
  273. { release interrupts }
  274. asm
  275. ei
  276. end;
  277. end;