+@ Compare
+TSST | SUBTRACT
+@ TOS> *blk2ptr-*blk1ptr, blk2ptr, blk1ptr, count
+NTSSSSTTSTTSSSSSSTSN | BRZ > 00011011 00000010 (jump if words match)
+
+@ Return 'match? = false'
+SNN | DROP
+SNN | DROP
+SNN | DROP
+SSSTN | PUSH 1
+NTN | RTS
+
+@ Decrement and loop again if loop is not complete.
+NSSVSSSTTSTTSSSSSSTSN | Mark: 00011011 00000010
+SSSTTN | PUSH 3
+NSTTTSSN | JSR > 1100 (deepdup)
+@ TOS> count, blk2ptr, blk1ptr, count
+NTSSSSTTSTTSSSSSSSTN | BRZ > 00011011 00000001 (jump if loop is complete)
+SSSTTN | PUSH 3
+NSTTSTTN | JSR > 1011 (stackrotatereverse)
+SSSTN | PUSH 1
+TSSS | ADD
+SSSTTN | PUSH 3
+NSTTSTSN | JSR > 1010 (stackrotate)
+NSNSSSTTSTTSSSSSSSSN | JMP > 00011011 00000000
+
+@ Return 'match? = true'
+NSSVSSSTTSTTSSSSSSSTN | Mark: 00011011 00000001
+SNN | DROP
+SNN | DROP
+SNN | DROP
+SSSSN | PUSH 0
+NTN | RTS
+
+@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
+@ Name:
+@ memsrch (11100)
+@ Description:
+@ Searches the heap from 'address' to 'address+count'.
+@ If 'pattern' is found, the return value is a pointer to the matching word.
+@ If not found, the return value is a null pointer.
+@ Call Stack:
+@ pattern
+@ count
+@ address <-- TOS
+@ Return Stack:
+@ pointer <-- TOS
+@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
+#include <stack.pvvs>
+NSSVTTTSSN | Mark: 11100 (memsrch)
+
+@ Setup an 'offset counter' on the stack.
+SSSSN | PUSH 0
+
+@ Compare one word on each pass through this loop.
+@ TOS> counter, address, count, pattern
+NSSVSSSTTTSSSSSSSSSSN | Mark: 00011100 00000000
+SNT | SWAP
+SNS | DUP
+SSSTTN | PUSH 3
+NSTTSTTN | JSR > 1011 (stackrotatereverse)
+SNS | DUP
+SSSTTN | PUSH 3
+NSTTSTTN | JSR > 1011 (stackrotatereverse)