Commit Diff


commit - 099e4c576c83e653f3220c05a8a471417a4de660
commit + 1192038877397dc033e0476f01342fe5ee0e7cfc
blob - 13a99173dc639cb6e6c7906bd472fbe285d6e321
blob + 55f8bb36bfd2c127efdc8fdb585932865f1a4478
--- Makefile
+++ Makefile
@@ -1,7 +1,7 @@
 CFLAGS += -Wall
 
 PROGS = hackem rom
-ROMS = add.rom max.rom term0.rom term1.rom term2.rom
+ROMS = add.rom max.rom term0.rom term1.rom term2.rom hello.rom
 
 .PHONY: all test clean
 all: ${PROGS} ${ROMS}
blob - /dev/null
blob + fdf6b15278c5829be6e013b99359e47338e568d1 (mode 644)
--- /dev/null
+++ hello.hack
@@ -0,0 +1,98 @@
+# simplified "hello world":
+# put out the characters "Hi\n" on the tape punch.
+
+# tape punch is mapped at address 0x7002 (28674), control word at 28675.
+
+
+			# jump to the beginning of the program:
+0 000000000010100	#  0: @20	= MAIN
+1 11 0 101010 000 111	#  1: 0;JMP
+
+
+#
+# PUTC: print character in R4, return to location in R3
+#
+			#     (PUTC)
+
+			# read control word until it becomes negative:
+0 111000000000011	#  2: @28675	= 0x7003
+1 11 1 110000 010 000	#  3: D=M;
+0 000000000000010	#  4: @2	= PUTC
+1 11 0 001100 000 011	#  5: D;JGE
+
+			# if bit 14 is set, terminate with error:
+0 100000000000000	#  6: @16384 (0x4000 = 2^14)
+1 11 0 000000 010 000	#  7: D=D&A;
+0 000000000001101	#  8: @13	= CONT
+1 11 0 001100 000 010	#  9: D;JEQ
+1 11 0 111111 010 000	# 10: D=1;
+0 000000000010011	# 11: @19	= END
+1 11 0 101010 000 111	# 12: 0;JMP
+			#     (CONT)
+
+			# write R4 to 0x7002:
+0 000000000000100	# 13: @4
+1 11 1 110000 010 000	# 14: D=M;
+0 111000000000010	# 15: @28674	= 0x7002
+1 11 0 001100 001 000 	# 16: M=D;
+
+			# jump to return address stored in R3
+0 000000000000011	# 17: @3
+1 11 1 110000 100 111	# 18: A=M;JMP
+
+
+#
+# END: terminate (infinite loop)
+#
+			#     (END)
+1 11 0 101010 000 111	# 19: 0;JMP
+
+
+#
+# MAIN: punch out message and terminate.
+#
+			#     (MAIN)
+
+			# call PUTC('H'):
+0 000000001001000	# 20: @72	= 'H'
+1 11 0 110000 010 000	# 21: D=A;
+0 000000000000100	# 22: @4
+1 11 0 001100 001 000	# 23: M=D;
+0 000000000011110	# 24: @30	= K1
+1 11 0 110000 010 000	# 25: D=A;
+0 000000000000011	# 26: @3
+1 11 0 001100 001 000	# 27: M=D;
+0 000000000000010	# 28: @2	= PUTC
+1 11 0 101010 000 111	# 29: 0;JMP
+			#     (K1)
+
+			# call PUTC('i'):
+0 000000001101001	# 30: @105	= 'i'
+1 11 0 110000 010 000	# 31: D=A;
+0 000000000000100	# 32: @4
+1 11 0 001100 001 000	# 33: M=D;
+0 000000000101000	# 34: @40	= K2
+1 11 0 110000 010 000	# 35: D=A;
+0 000000000000011	# 36: @3
+1 11 0 001100 001 000	# 37: M=D;
+0 000000000000010	# 38: @2	= PUTC
+1 11 0 101010 000 111	# 39: 0;JMP
+			#     (K2)
+
+			# call PUTC('\n'):
+0 000000000001010	# 40: @10	= '\n'
+1 11 0 110000 010 000	# 41: D=A;
+0 000000000000100	# 42: @4
+1 11 0 001100 001 000	# 43: M=D;
+0 000000000110010	# 44: @50	= K3
+1 11 0 110000 010 000	# 45: D=A;
+0 000000000000011	# 46: @3
+1 11 0 001100 001 000	# 47: M=D;
+0 000000000000010	# 48: @2	= PUTC
+1 11 0 101010 000 111	# 49: 0;JMP
+			#     (K3)
+
+			# terminate successfully:
+1 11 0 101010 010 000	# 50: D=0;
+0 000000000010011	# 51: @19	= END
+1 11 0 101010 000 111	# 52: 0;JMP
blob - /dev/null
blob + dfb39a8480e8f6942b2e36e73b9c94ec85489f7b (mode 644)
--- /dev/null
+++ hello.tsv
@@ -0,0 +1,351 @@
+T	PC	instr.	A	D	R0/SP	R1/LCL	R2/ARG	R3/THIS	R4/THAT
+0	0	000024	0	0	0	0	0	0	0
+1	1	165207	20	0	0	0	0	0	0
+2	20	000110	20	0	0	0	0	0	0
+3	21	166020	72	0	0	0	0	0	0
+4	22	000004	72	72	0	0	0	0	0
+5	23	161410	4	72	0	0	0	0	0
+6	24	000036	4	72	0	0	0	0	72
+7	25	166020	30	72	0	0	0	0	72
+8	26	000003	30	30	0	0	0	0	72
+9	27	161410	3	30	0	0	0	0	72
+10	28	000002	3	30	0	0	0	30	72
+11	29	165207	2	30	0	0	0	30	72
+12	2	070003	2	30	0	0	0	30	72
+13	3	176020	28675	30	0	0	0	30	72
+14	4	000002	28675	-32768	0	0	0	30	72
+15	5	161403	2	-32768	0	0	0	30	72
+16	6	040000	2	-32768	0	0	0	30	72
+17	7	160020	16384	-32768	0	0	0	30	72
+18	8	000015	16384	0	0	0	0	30	72
+19	9	161402	13	0	0	0	0	30	72
+20	13	000004	13	0	0	0	0	30	72
+21	14	176020	4	0	0	0	0	30	72
+22	15	070002	4	72	0	0	0	30	72
+23	16	161410	28674	72	0	0	0	30	72
+24	17	000003	28674	72	0	0	0	30	72
+25	18	176047	3	72	0	0	0	30	72
+26	30	000151	30	72	0	0	0	30	72
+27	31	166020	105	72	0	0	0	30	72
+28	32	000004	105	105	0	0	0	30	72
+29	33	161410	4	105	0	0	0	30	72
+30	34	000050	4	105	0	0	0	30	105
+31	35	166020	40	105	0	0	0	30	105
+32	36	000003	40	40	0	0	0	30	105
+33	37	161410	3	40	0	0	0	30	105
+34	38	000002	3	40	0	0	0	40	105
+35	39	165207	2	40	0	0	0	40	105
+36	2	070003	2	40	0	0	0	40	105
+37	3	176020	28675	40	0	0	0	40	105
+38	4	000002	28675	0	0	0	0	40	105
+39	5	161403	2	0	0	0	0	40	105
+40	2	070003	2	0	0	0	0	40	105
+41	3	176020	28675	0	0	0	0	40	105
+42	4	000002	28675	0	0	0	0	40	105
+43	5	161403	2	0	0	0	0	40	105
+44	2	070003	2	0	0	0	0	40	105
+45	3	176020	28675	0	0	0	0	40	105
+46	4	000002	28675	0	0	0	0	40	105
+47	5	161403	2	0	0	0	0	40	105
+48	2	070003	2	0	0	0	0	40	105
+49	3	176020	28675	0	0	0	0	40	105
+50	4	000002	28675	0	0	0	0	40	105
+51	5	161403	2	0	0	0	0	40	105
+52	2	070003	2	0	0	0	0	40	105
+53	3	176020	28675	0	0	0	0	40	105
+54	4	000002	28675	0	0	0	0	40	105
+55	5	161403	2	0	0	0	0	40	105
+56	2	070003	2	0	0	0	0	40	105
+57	3	176020	28675	0	0	0	0	40	105
+58	4	000002	28675	0	0	0	0	40	105
+59	5	161403	2	0	0	0	0	40	105
+60	2	070003	2	0	0	0	0	40	105
+61	3	176020	28675	0	0	0	0	40	105
+62	4	000002	28675	0	0	0	0	40	105
+63	5	161403	2	0	0	0	0	40	105
+64	2	070003	2	0	0	0	0	40	105
+65	3	176020	28675	0	0	0	0	40	105
+66	4	000002	28675	0	0	0	0	40	105
+67	5	161403	2	0	0	0	0	40	105
+68	2	070003	2	0	0	0	0	40	105
+69	3	176020	28675	0	0	0	0	40	105
+70	4	000002	28675	0	0	0	0	40	105
+71	5	161403	2	0	0	0	0	40	105
+72	2	070003	2	0	0	0	0	40	105
+73	3	176020	28675	0	0	0	0	40	105
+74	4	000002	28675	0	0	0	0	40	105
+75	5	161403	2	0	0	0	0	40	105
+76	2	070003	2	0	0	0	0	40	105
+77	3	176020	28675	0	0	0	0	40	105
+78	4	000002	28675	0	0	0	0	40	105
+79	5	161403	2	0	0	0	0	40	105
+80	2	070003	2	0	0	0	0	40	105
+81	3	176020	28675	0	0	0	0	40	105
+82	4	000002	28675	0	0	0	0	40	105
+83	5	161403	2	0	0	0	0	40	105
+84	2	070003	2	0	0	0	0	40	105
+85	3	176020	28675	0	0	0	0	40	105
+86	4	000002	28675	0	0	0	0	40	105
+87	5	161403	2	0	0	0	0	40	105
+88	2	070003	2	0	0	0	0	40	105
+89	3	176020	28675	0	0	0	0	40	105
+90	4	000002	28675	0	0	0	0	40	105
+91	5	161403	2	0	0	0	0	40	105
+92	2	070003	2	0	0	0	0	40	105
+93	3	176020	28675	0	0	0	0	40	105
+94	4	000002	28675	0	0	0	0	40	105
+95	5	161403	2	0	0	0	0	40	105
+96	2	070003	2	0	0	0	0	40	105
+97	3	176020	28675	0	0	0	0	40	105
+98	4	000002	28675	0	0	0	0	40	105
+99	5	161403	2	0	0	0	0	40	105
+100	2	070003	2	0	0	0	0	40	105
+101	3	176020	28675	0	0	0	0	40	105
+102	4	000002	28675	0	0	0	0	40	105
+103	5	161403	2	0	0	0	0	40	105
+104	2	070003	2	0	0	0	0	40	105
+105	3	176020	28675	0	0	0	0	40	105
+106	4	000002	28675	0	0	0	0	40	105
+107	5	161403	2	0	0	0	0	40	105
+108	2	070003	2	0	0	0	0	40	105
+109	3	176020	28675	0	0	0	0	40	105
+110	4	000002	28675	0	0	0	0	40	105
+111	5	161403	2	0	0	0	0	40	105
+112	2	070003	2	0	0	0	0	40	105
+113	3	176020	28675	0	0	0	0	40	105
+114	4	000002	28675	0	0	0	0	40	105
+115	5	161403	2	0	0	0	0	40	105
+116	2	070003	2	0	0	0	0	40	105
+117	3	176020	28675	0	0	0	0	40	105
+118	4	000002	28675	0	0	0	0	40	105
+119	5	161403	2	0	0	0	0	40	105
+120	2	070003	2	0	0	0	0	40	105
+121	3	176020	28675	0	0	0	0	40	105
+122	4	000002	28675	0	0	0	0	40	105
+123	5	161403	2	0	0	0	0	40	105
+124	2	070003	2	0	0	0	0	40	105
+125	3	176020	28675	0	0	0	0	40	105
+126	4	000002	28675	0	0	0	0	40	105
+127	5	161403	2	0	0	0	0	40	105
+128	2	070003	2	0	0	0	0	40	105
+129	3	176020	28675	0	0	0	0	40	105
+130	4	000002	28675	0	0	0	0	40	105
+131	5	161403	2	0	0	0	0	40	105
+132	2	070003	2	0	0	0	0	40	105
+133	3	176020	28675	0	0	0	0	40	105
+134	4	000002	28675	0	0	0	0	40	105
+135	5	161403	2	0	0	0	0	40	105
+136	2	070003	2	0	0	0	0	40	105
+137	3	176020	28675	0	0	0	0	40	105
+138	4	000002	28675	0	0	0	0	40	105
+139	5	161403	2	0	0	0	0	40	105
+140	2	070003	2	0	0	0	0	40	105
+141	3	176020	28675	0	0	0	0	40	105
+142	4	000002	28675	0	0	0	0	40	105
+143	5	161403	2	0	0	0	0	40	105
+144	2	070003	2	0	0	0	0	40	105
+145	3	176020	28675	0	0	0	0	40	105
+146	4	000002	28675	0	0	0	0	40	105
+147	5	161403	2	0	0	0	0	40	105
+148	2	070003	2	0	0	0	0	40	105
+149	3	176020	28675	0	0	0	0	40	105
+150	4	000002	28675	0	0	0	0	40	105
+151	5	161403	2	0	0	0	0	40	105
+152	2	070003	2	0	0	0	0	40	105
+153	3	176020	28675	0	0	0	0	40	105
+154	4	000002	28675	0	0	0	0	40	105
+155	5	161403	2	0	0	0	0	40	105
+156	2	070003	2	0	0	0	0	40	105
+157	3	176020	28675	0	0	0	0	40	105
+158	4	000002	28675	0	0	0	0	40	105
+159	5	161403	2	0	0	0	0	40	105
+160	2	070003	2	0	0	0	0	40	105
+161	3	176020	28675	0	0	0	0	40	105
+162	4	000002	28675	0	0	0	0	40	105
+163	5	161403	2	0	0	0	0	40	105
+164	2	070003	2	0	0	0	0	40	105
+165	3	176020	28675	0	0	0	0	40	105
+166	4	000002	28675	0	0	0	0	40	105
+167	5	161403	2	0	0	0	0	40	105
+168	2	070003	2	0	0	0	0	40	105
+169	3	176020	28675	0	0	0	0	40	105
+170	4	000002	28675	0	0	0	0	40	105
+171	5	161403	2	0	0	0	0	40	105
+172	2	070003	2	0	0	0	0	40	105
+173	3	176020	28675	0	0	0	0	40	105
+174	4	000002	28675	-32768	0	0	0	40	105
+175	5	161403	2	-32768	0	0	0	40	105
+176	6	040000	2	-32768	0	0	0	40	105
+177	7	160020	16384	-32768	0	0	0	40	105
+178	8	000015	16384	0	0	0	0	40	105
+179	9	161402	13	0	0	0	0	40	105
+180	13	000004	13	0	0	0	0	40	105
+181	14	176020	4	0	0	0	0	40	105
+182	15	070002	4	105	0	0	0	40	105
+183	16	161410	28674	105	0	0	0	40	105
+184	17	000003	28674	105	0	0	0	40	105
+185	18	176047	3	105	0	0	0	40	105
+186	40	000012	40	105	0	0	0	40	105
+187	41	166020	10	105	0	0	0	40	105
+188	42	000004	10	10	0	0	0	40	105
+189	43	161410	4	10	0	0	0	40	105
+190	44	000062	4	10	0	0	0	40	10
+191	45	166020	50	10	0	0	0	40	10
+192	46	000003	50	50	0	0	0	40	10
+193	47	161410	3	50	0	0	0	40	10
+194	48	000002	3	50	0	0	0	50	10
+195	49	165207	2	50	0	0	0	50	10
+196	2	070003	2	50	0	0	0	50	10
+197	3	176020	28675	50	0	0	0	50	10
+198	4	000002	28675	0	0	0	0	50	10
+199	5	161403	2	0	0	0	0	50	10
+200	2	070003	2	0	0	0	0	50	10
+201	3	176020	28675	0	0	0	0	50	10
+202	4	000002	28675	0	0	0	0	50	10
+203	5	161403	2	0	0	0	0	50	10
+204	2	070003	2	0	0	0	0	50	10
+205	3	176020	28675	0	0	0	0	50	10
+206	4	000002	28675	0	0	0	0	50	10
+207	5	161403	2	0	0	0	0	50	10
+208	2	070003	2	0	0	0	0	50	10
+209	3	176020	28675	0	0	0	0	50	10
+210	4	000002	28675	0	0	0	0	50	10
+211	5	161403	2	0	0	0	0	50	10
+212	2	070003	2	0	0	0	0	50	10
+213	3	176020	28675	0	0	0	0	50	10
+214	4	000002	28675	0	0	0	0	50	10
+215	5	161403	2	0	0	0	0	50	10
+216	2	070003	2	0	0	0	0	50	10
+217	3	176020	28675	0	0	0	0	50	10
+218	4	000002	28675	0	0	0	0	50	10
+219	5	161403	2	0	0	0	0	50	10
+220	2	070003	2	0	0	0	0	50	10
+221	3	176020	28675	0	0	0	0	50	10
+222	4	000002	28675	0	0	0	0	50	10
+223	5	161403	2	0	0	0	0	50	10
+224	2	070003	2	0	0	0	0	50	10
+225	3	176020	28675	0	0	0	0	50	10
+226	4	000002	28675	0	0	0	0	50	10
+227	5	161403	2	0	0	0	0	50	10
+228	2	070003	2	0	0	0	0	50	10
+229	3	176020	28675	0	0	0	0	50	10
+230	4	000002	28675	0	0	0	0	50	10
+231	5	161403	2	0	0	0	0	50	10
+232	2	070003	2	0	0	0	0	50	10
+233	3	176020	28675	0	0	0	0	50	10
+234	4	000002	28675	0	0	0	0	50	10
+235	5	161403	2	0	0	0	0	50	10
+236	2	070003	2	0	0	0	0	50	10
+237	3	176020	28675	0	0	0	0	50	10
+238	4	000002	28675	0	0	0	0	50	10
+239	5	161403	2	0	0	0	0	50	10
+240	2	070003	2	0	0	0	0	50	10
+241	3	176020	28675	0	0	0	0	50	10
+242	4	000002	28675	0	0	0	0	50	10
+243	5	161403	2	0	0	0	0	50	10
+244	2	070003	2	0	0	0	0	50	10
+245	3	176020	28675	0	0	0	0	50	10
+246	4	000002	28675	0	0	0	0	50	10
+247	5	161403	2	0	0	0	0	50	10
+248	2	070003	2	0	0	0	0	50	10
+249	3	176020	28675	0	0	0	0	50	10
+250	4	000002	28675	0	0	0	0	50	10
+251	5	161403	2	0	0	0	0	50	10
+252	2	070003	2	0	0	0	0	50	10
+253	3	176020	28675	0	0	0	0	50	10
+254	4	000002	28675	0	0	0	0	50	10
+255	5	161403	2	0	0	0	0	50	10
+256	2	070003	2	0	0	0	0	50	10
+257	3	176020	28675	0	0	0	0	50	10
+258	4	000002	28675	0	0	0	0	50	10
+259	5	161403	2	0	0	0	0	50	10
+260	2	070003	2	0	0	0	0	50	10
+261	3	176020	28675	0	0	0	0	50	10
+262	4	000002	28675	0	0	0	0	50	10
+263	5	161403	2	0	0	0	0	50	10
+264	2	070003	2	0	0	0	0	50	10
+265	3	176020	28675	0	0	0	0	50	10
+266	4	000002	28675	0	0	0	0	50	10
+267	5	161403	2	0	0	0	0	50	10
+268	2	070003	2	0	0	0	0	50	10
+269	3	176020	28675	0	0	0	0	50	10
+270	4	000002	28675	0	0	0	0	50	10
+271	5	161403	2	0	0	0	0	50	10
+272	2	070003	2	0	0	0	0	50	10
+273	3	176020	28675	0	0	0	0	50	10
+274	4	000002	28675	0	0	0	0	50	10
+275	5	161403	2	0	0	0	0	50	10
+276	2	070003	2	0	0	0	0	50	10
+277	3	176020	28675	0	0	0	0	50	10
+278	4	000002	28675	0	0	0	0	50	10
+279	5	161403	2	0	0	0	0	50	10
+280	2	070003	2	0	0	0	0	50	10
+281	3	176020	28675	0	0	0	0	50	10
+282	4	000002	28675	0	0	0	0	50	10
+283	5	161403	2	0	0	0	0	50	10
+284	2	070003	2	0	0	0	0	50	10
+285	3	176020	28675	0	0	0	0	50	10
+286	4	000002	28675	0	0	0	0	50	10
+287	5	161403	2	0	0	0	0	50	10
+288	2	070003	2	0	0	0	0	50	10
+289	3	176020	28675	0	0	0	0	50	10
+290	4	000002	28675	0	0	0	0	50	10
+291	5	161403	2	0	0	0	0	50	10
+292	2	070003	2	0	0	0	0	50	10
+293	3	176020	28675	0	0	0	0	50	10
+294	4	000002	28675	0	0	0	0	50	10
+295	5	161403	2	0	0	0	0	50	10
+296	2	070003	2	0	0	0	0	50	10
+297	3	176020	28675	0	0	0	0	50	10
+298	4	000002	28675	0	0	0	0	50	10
+299	5	161403	2	0	0	0	0	50	10
+300	2	070003	2	0	0	0	0	50	10
+301	3	176020	28675	0	0	0	0	50	10
+302	4	000002	28675	0	0	0	0	50	10
+303	5	161403	2	0	0	0	0	50	10
+304	2	070003	2	0	0	0	0	50	10
+305	3	176020	28675	0	0	0	0	50	10
+306	4	000002	28675	0	0	0	0	50	10
+307	5	161403	2	0	0	0	0	50	10
+308	2	070003	2	0	0	0	0	50	10
+309	3	176020	28675	0	0	0	0	50	10
+310	4	000002	28675	0	0	0	0	50	10
+311	5	161403	2	0	0	0	0	50	10
+312	2	070003	2	0	0	0	0	50	10
+313	3	176020	28675	0	0	0	0	50	10
+314	4	000002	28675	0	0	0	0	50	10
+315	5	161403	2	0	0	0	0	50	10
+316	2	070003	2	0	0	0	0	50	10
+317	3	176020	28675	0	0	0	0	50	10
+318	4	000002	28675	0	0	0	0	50	10
+319	5	161403	2	0	0	0	0	50	10
+320	2	070003	2	0	0	0	0	50	10
+321	3	176020	28675	0	0	0	0	50	10
+322	4	000002	28675	0	0	0	0	50	10
+323	5	161403	2	0	0	0	0	50	10
+324	2	070003	2	0	0	0	0	50	10
+325	3	176020	28675	0	0	0	0	50	10
+326	4	000002	28675	0	0	0	0	50	10
+327	5	161403	2	0	0	0	0	50	10
+328	2	070003	2	0	0	0	0	50	10
+329	3	176020	28675	0	0	0	0	50	10
+330	4	000002	28675	0	0	0	0	50	10
+331	5	161403	2	0	0	0	0	50	10
+332	2	070003	2	0	0	0	0	50	10
+333	3	176020	28675	0	0	0	0	50	10
+334	4	000002	28675	-32768	0	0	0	50	10
+335	5	161403	2	-32768	0	0	0	50	10
+336	6	040000	2	-32768	0	0	0	50	10
+337	7	160020	16384	-32768	0	0	0	50	10
+338	8	000015	16384	0	0	0	0	50	10
+339	9	161402	13	0	0	0	0	50	10
+340	13	000004	13	0	0	0	0	50	10
+341	14	176020	4	0	0	0	0	50	10
+342	15	070002	4	10	0	0	0	50	10
+343	16	161410	28674	10	0	0	0	50	10
+344	17	000003	28674	10	0	0	0	50	10
+345	18	176047	3	10	0	0	0	50	10
+346	50	165220	50	10	0	0	0	50	10
+347	51	000023	50	0	0	0	0	50	10
+348	52	165207	19	0	0	0	0	50	10
+349	19	165207	19	0	0	0	0	50	10