ack/tests/plat/core/and_e.e
David Given 88fd7b3cdc Add a 'kill' pseudoinstruction to the 8080 assembler, which marks when the code
generator is finished with a register; use this to create some more effective
peephole optimiser rules.
2019-03-08 23:06:34 +01:00

129 lines
1.2 KiB
Text

#
mes 2, EM_WSIZE, EM_PSIZE
exp $_m_a_i_n
pro $_m_a_i_n, 0
three
rom 3
one
rom 1
mone
rom -1
big
rom 256
/* And var with var */
loe three
loe one
and EM_WSIZE
loc 1
cmu EM_WSIZE
zeq *1
loc __LINE__
cal $fail
asp 4
1
/* And var with const */
loe three
loc 1
and EM_WSIZE
loc 1
cmu EM_WSIZE
zeq *2
loc __LINE__
cal $fail
asp 4
2
/* And const with var */
loc 3
loe one
and EM_WSIZE
loc 1
cmu EM_WSIZE
zeq *3
loc __LINE__
cal $fail
asp 4
3
/* And var with big const */
loe big
loc 257
and EM_WSIZE
loc 256
cmu EM_WSIZE
zeq *4
loc __LINE__
cal $fail
asp 4
4
/* And big const with var */
loc 257
loe big
and EM_WSIZE
loc 256
cmu EM_WSIZE
zeq *5
loc __LINE__
cal $fail
asp 4
5
/* And big const with negative var */
loc 257
loe mone
and EM_WSIZE
loc 257
cmu EM_WSIZE
zeq *6
loc __LINE__
cal $fail
asp 4
6
/* And big var with negative const */
loe big
loc -1
and EM_WSIZE
loe big
cmu EM_WSIZE
zeq *7
loc __LINE__
cal $fail
asp 4
7
/* And var with big low-byte-zero const */
loe big
loc 256
and EM_WSIZE
loc 256
cmu EM_WSIZE
zeq *8
loc __LINE__
cal $fail
asp 4
8
cal $finished
end