shithub: scc

ref: 6a8265d1262a3c63665f78a29d59d84387e8f68a
dir: /cc2/peep.c/

View raw version

#include <inttypes.h>
#include <stddef.h>

#include "../inc/cc.h"
#include "cc2.h"

void
peephole(void)
{
	Addr to, from;
	TINT i;
	uint8_t op;

	for (pc = prog; pc; pc = pc->next) {
		to = pc->to;
		from = pc->from;

		switch (pc->op) {
		case SUB:
		case ADD:
			if (from.kind == CONST) {
				if ((i = from.u.i) == 0 || i < 4) {
					delcode();
					op = (pc->op == ADD) ? INC : DEC;

					while (i--)
						inscode(op, &to, NULL);
				}
			/* TODO: More optimizations (ex: -1) */
			}
			break;
		case JP:
			if (to.u.sym->u.pc == pc->next)
				delcode();
			break;
		}
	}
}