sfb3.awl 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401
  1. ORGANIZATION_BLOCK OB 1
  2. BEGIN
  3. // Check instance-DB length
  4. AUF DB 1
  5. L DBLG
  6. __ASSERT== __ACCU 1, 22
  7. AUF DB 0
  8. // Check TP pulse
  9. CALL SFB 3, DB 1 (
  10. IN := FALSE,
  11. PT := T#0S,
  12. Q := M 0.0,
  13. ET := MD 2,
  14. )
  15. __ASSERT== __STW BIE, 1
  16. U M 0.0
  17. __ASSERT== __STW VKE, 0
  18. L MD 2
  19. __ASSERT== __ACCU 1, 0
  20. L DB1.DBB 12 // STATE
  21. __ASSERT== __ACCU 1, 0
  22. L DB1.DBD 18 // ATIME
  23. L DB1.DBD 14 // STIME
  24. __ASSERT== __ACCU 1, 0
  25. -D
  26. UD DW#16#7FFFFFFF
  27. __ASSERT== __ACCU 1, 0
  28. CALL SFB 3, DB 1 (
  29. IN := FALSE,
  30. PT := T#500MS,
  31. Q := M 0.0,
  32. ET := MD 2,
  33. )
  34. __ASSERT== __STW BIE, 1
  35. U M 0.0
  36. __ASSERT== __STW VKE, 0
  37. L MD 2
  38. __ASSERT== __ACCU 1, 0
  39. L DB1.DBB 12 // STATE
  40. __ASSERT== __ACCU 1, 0
  41. L DB1.DBD 18 // ATIME
  42. L DB1.DBD 14 // STIME
  43. __ASSERT== __ACCU 1, 0
  44. -D
  45. UD DW#16#7FFFFFFF
  46. __ASSERT== __ACCU 1, 0
  47. CALL SFB 3, DB 1 (
  48. IN := TRUE,
  49. PT := T#500MS,
  50. Q := M 0.0,
  51. ET := MD 2,
  52. )
  53. __ASSERT== __STW BIE, 1
  54. U M 0.0
  55. __ASSERT== __STW VKE, 1
  56. L MD 2
  57. __ASSERT>= __ACCU 1, 0
  58. L DB1.DBB 12 // STATE
  59. __ASSERT== __ACCU 1, 1
  60. L DB1.DBD 18 // ATIME
  61. L DB1.DBD 14 // STIME
  62. -D
  63. UD DW#16#7FFFFFFF
  64. __ASSERT== __ACCU 1, 0
  65. __SLEEP 400
  66. CALL SFB 3, DB 1 (
  67. IN := TRUE,
  68. PT := T#500MS,
  69. Q := M 0.0,
  70. ET := MD 2,
  71. )
  72. __ASSERT== __STW BIE, 1
  73. U M 0.0
  74. __ASSERT== __STW VKE, 1
  75. L MD 2
  76. __ASSERT>= __ACCU 1, 400
  77. __ASSERT< __ACCU 1, 500
  78. L DB1.DBB 12 // STATE
  79. __ASSERT== __ACCU 1, 1
  80. L DB1.DBD 18 // ATIME
  81. L DB1.DBD 14 // STIME
  82. -D
  83. UD DW#16#7FFFFFFF
  84. __ASSERT>= __ACCU 1, 400
  85. __ASSERT< __ACCU 1, 500
  86. __SLEEP 250
  87. CALL SFB 3, DB 1 (
  88. IN := TRUE,
  89. PT := T#500MS,
  90. Q := M 0.0,
  91. ET := MD 2,
  92. )
  93. __ASSERT== __STW BIE, 1
  94. U M 0.0
  95. __ASSERT== __STW VKE, 0
  96. L MD 2
  97. __ASSERT== __ACCU 1, 500
  98. L DB1.DBB 12 // STATE
  99. __ASSERT== __ACCU 1, 2
  100. L DB1.DBD 18 // ATIME
  101. L DB1.DBD 14 // STIME
  102. -D
  103. UD DW#16#7FFFFFFF
  104. __ASSERT>= __ACCU 1, 500
  105. CALL SFB 3, DB 1 (
  106. IN := FALSE,
  107. PT := T#500MS,
  108. Q := M 0.0,
  109. ET := MD 2,
  110. )
  111. __ASSERT== __STW BIE, 1
  112. U M 0.0
  113. __ASSERT== __STW VKE, 0
  114. L MD 2
  115. __ASSERT== __ACCU 1, 0
  116. L DB1.DBB 12 // STATE
  117. __ASSERT== __ACCU 1, 0
  118. L DB1.DBD 18 // ATIME
  119. L DB1.DBD 14 // STIME
  120. -D
  121. UD DW#16#7FFFFFFF
  122. __ASSERT>= __ACCU 1, 500
  123. // Test: Interrupt IN before time elapsed
  124. CALL SFB 3, DB 1 (
  125. IN := TRUE,
  126. PT := T#500MS,
  127. Q := M 0.0,
  128. ET := MD 2,
  129. )
  130. __ASSERT== __STW BIE, 1
  131. U M 0.0
  132. __ASSERT== __STW VKE, 1
  133. L MD 2
  134. __ASSERT>= __ACCU 1, 0
  135. L DB1.DBB 12 // STATE
  136. __ASSERT== __ACCU 1, 1
  137. L DB1.DBD 18 // ATIME
  138. L DB1.DBD 14 // STIME
  139. -D
  140. UD DW#16#7FFFFFFF
  141. __ASSERT== __ACCU 1, 0
  142. __SLEEP 100
  143. CALL SFB 3, DB 1 (
  144. IN := TRUE,
  145. PT := T#500MS,
  146. Q := M 0.0,
  147. ET := MD 2,
  148. )
  149. __ASSERT== __STW BIE, 1
  150. U M 0.0
  151. __ASSERT== __STW VKE, 1
  152. L MD 2
  153. __ASSERT> __ACCU 1, 50
  154. __ASSERT< __ACCU 1, 150
  155. L DB1.DBB 12 // STATE
  156. __ASSERT== __ACCU 1, 1
  157. L DB1.DBD 18 // ATIME
  158. L DB1.DBD 14 // STIME
  159. -D
  160. UD DW#16#7FFFFFFF
  161. __ASSERT> __ACCU 1, 50
  162. __ASSERT< __ACCU 1, 150
  163. __SLEEP 100
  164. CALL SFB 3, DB 1 (
  165. IN := FALSE,
  166. PT := T#500MS,
  167. Q := M 0.0,
  168. ET := MD 2,
  169. )
  170. __ASSERT== __STW BIE, 1
  171. U M 0.0
  172. __ASSERT== __STW VKE, 1
  173. L MD 2
  174. __ASSERT> __ACCU 1, 150
  175. __ASSERT< __ACCU 1, 250
  176. L DB1.DBB 12 // STATE
  177. __ASSERT== __ACCU 1, 1
  178. L DB1.DBD 18 // ATIME
  179. L DB1.DBD 14 // STIME
  180. -D
  181. UD DW#16#7FFFFFFF
  182. __ASSERT> __ACCU 1, 150
  183. __ASSERT< __ACCU 1, 250
  184. __SLEEP 500
  185. CALL SFB 3, DB 1 (
  186. IN := FALSE,
  187. PT := T#500MS,
  188. Q := M 0.0,
  189. ET := MD 2,
  190. )
  191. __ASSERT== __STW BIE, 1
  192. U M 0.0
  193. __ASSERT== __STW VKE, 0
  194. L MD 2
  195. __ASSERT== __ACCU 1, 0
  196. L DB1.DBB 12 // STATE
  197. __ASSERT== __ACCU 1, 0
  198. L DB1.DBD 18 // ATIME
  199. L DB1.DBD 14 // STIME
  200. -D
  201. UD DW#16#7FFFFFFF
  202. __ASSERT>= __ACCU 1, 500
  203. // Test: Change PT while running
  204. CALL SFB 3, DB 1 (
  205. IN := TRUE,
  206. PT := T#500MS,
  207. Q := M 0.0,
  208. ET := MD 2,
  209. )
  210. __ASSERT== __STW BIE, 1
  211. U M 0.0
  212. __ASSERT== __STW VKE, 1
  213. L MD 2
  214. __ASSERT>= __ACCU 1, 0
  215. L DB1.DBB 12 // STATE
  216. __ASSERT== __ACCU 1, 1
  217. L DB1.DBD 18 // ATIME
  218. L DB1.DBD 14 // STIME
  219. -D
  220. UD DW#16#7FFFFFFF
  221. __ASSERT== __ACCU 1, 0
  222. __SLEEP 100
  223. CALL SFB 3, DB 1 (
  224. IN := TRUE,
  225. PT := T#500MS,
  226. Q := M 0.0,
  227. ET := MD 2,
  228. )
  229. __ASSERT== __STW BIE, 1
  230. U M 0.0
  231. __ASSERT== __STW VKE, 1
  232. L MD 2
  233. __ASSERT> __ACCU 1, 50
  234. __ASSERT< __ACCU 1, 150
  235. L DB1.DBB 12 // STATE
  236. __ASSERT== __ACCU 1, 1
  237. L DB1.DBD 18 // ATIME
  238. L DB1.DBD 14 // STIME
  239. -D
  240. UD DW#16#7FFFFFFF
  241. __ASSERT> __ACCU 1, 50
  242. __ASSERT< __ACCU 1, 150
  243. CALL SFB 3, DB 1 (
  244. IN := TRUE,
  245. PT := T#0MS,
  246. Q := M 0.0,
  247. ET := MD 2,
  248. )
  249. __ASSERT== __STW BIE, 1
  250. U M 0.0
  251. __ASSERT== __STW VKE, 0
  252. L MD 2
  253. __ASSERT== __ACCU 1, 0
  254. L DB1.DBB 12 // STATE
  255. __ASSERT== __ACCU 1, 0
  256. L DB1.DBD 18 // ATIME
  257. L DB1.DBD 14 // STIME
  258. -D
  259. UD DW#16#7FFFFFFF
  260. __ASSERT> __ACCU 1, 50
  261. __ASSERT< __ACCU 1, 150
  262. CALL SFB 3, DB 1 (
  263. IN := FALSE,
  264. PT := T#0MS,
  265. Q := M 0.0,
  266. ET := MD 2,
  267. )
  268. __ASSERT== __STW BIE, 1
  269. U M 0.0
  270. __ASSERT== __STW VKE, 0
  271. L MD 2
  272. __ASSERT== __ACCU 1, 0
  273. L DB1.DBB 12 // STATE
  274. __ASSERT== __ACCU 1, 0
  275. L DB1.DBD 18 // ATIME
  276. L DB1.DBD 14 // STIME
  277. -D
  278. UD DW#16#7FFFFFFF
  279. __ASSERT> __ACCU 1, 50
  280. __ASSERT< __ACCU 1, 150
  281. // Test: At PT=0 the timer is not started
  282. CALL SFB 3, DB 1 (
  283. IN := TRUE,
  284. PT := T#0MS,
  285. Q := M 0.0,
  286. ET := MD 2,
  287. )
  288. __ASSERT== __STW BIE, 1
  289. U M 0.0
  290. __ASSERT== __STW VKE, 0
  291. L MD 2
  292. __ASSERT== __ACCU 1, 0
  293. L DB1.DBB 12 // STATE
  294. __ASSERT== __ACCU 1, 0
  295. L DB1.DBD 18 // ATIME
  296. L DB1.DBD 14 // STIME
  297. -D
  298. UD DW#16#7FFFFFFF
  299. __ASSERT> __ACCU 1, 50
  300. __ASSERT< __ACCU 1, 150
  301. U DB1.DBX 0.0 // IN
  302. __ASSERT== __STW VKE, 0 // IN will be forced low.
  303. CALL SFB 3, DB 1 (
  304. IN := FALSE,
  305. PT := T#0MS,
  306. Q := M 0.0,
  307. ET := MD 2,
  308. )
  309. __ASSERT== __STW BIE, 1
  310. U M 0.0
  311. __ASSERT== __STW VKE, 0
  312. L MD 2
  313. __ASSERT== __ACCU 1, 0
  314. L DB1.DBB 12 // STATE
  315. __ASSERT== __ACCU 1, 0
  316. L DB1.DBD 18 // ATIME
  317. L DB1.DBD 14 // STIME
  318. -D
  319. UD DW#16#7FFFFFFF
  320. __ASSERT> __ACCU 1, 50
  321. __ASSERT< __ACCU 1, 150
  322. U DB1.DBX 0.0 // IN
  323. __ASSERT== __STW VKE, 0
  324. // Test: Negative PT causes an error condition (BIE=0)
  325. CALL SFB 3, DB 1 (
  326. IN := TRUE,
  327. PT := T#-500MS,
  328. Q := M 0.0,
  329. ET := MD 2,
  330. )
  331. __ASSERT== __STW BIE, 0
  332. U M 0.0
  333. __ASSERT== __STW VKE, 0
  334. L MD 2
  335. __ASSERT== __ACCU 1, 0
  336. L DB1.DBB 12 // STATE
  337. __ASSERT== __ACCU 1, 0
  338. L DB1.DBD 18 // ATIME
  339. L DB1.DBD 14 // STIME
  340. -D
  341. UD DW#16#7FFFFFFF
  342. __ASSERT> __ACCU 1, 50
  343. __ASSERT< __ACCU 1, 150
  344. U DB1.DBX 0.0 // IN
  345. __ASSERT== __STW VKE, 1 // IN is not forced low.
  346. CALL SFB 3, DB 1 (
  347. IN := FALSE,
  348. PT := T#-500MS,
  349. Q := M 0.0,
  350. ET := MD 2,
  351. )
  352. __ASSERT== __STW BIE, 0
  353. U M 0.0
  354. __ASSERT== __STW VKE, 0
  355. L MD 2
  356. __ASSERT== __ACCU 1, 0
  357. L DB1.DBB 12 // STATE
  358. __ASSERT== __ACCU 1, 0
  359. L DB1.DBD 18 // ATIME
  360. L DB1.DBD 14 // STIME
  361. -D
  362. UD DW#16#7FFFFFFF
  363. __ASSERT> __ACCU 1, 50
  364. __ASSERT< __ACCU 1, 150
  365. U DB1.DBX 0.0 // IN
  366. __ASSERT== __STW VKE, 0
  367. CALL SFC 46 // STOP CPU
  368. END_ORGANIZATION_BLOCK
  369. DATA_BLOCK DB 1
  370. SFB 3
  371. BEGIN
  372. END_DATA_BLOCK