#include "assert.h" #include "equiv.h" #include "param.h" #include "tables.h" #include "types.h" #include #include "data.h" #include "result.h" #include "extern.h" /* * (c) copyright 1983 by the Vrije Universiteit, Amsterdam, The Netherlands. * * This product is part of the Amsterdam Compiler Kit. * * Permission to use, sell, duplicate or disclose this software must be * obtained in writing. Requests for such permissions may be sent to * * Dr. Andrew S. Tanenbaum * Wiskundig Seminarium * Vrije Universiteit * Postbox 7161 * 1007 MC Amsterdam * The Netherlands * * Author: Hans van Staveren */ extern string myalloc(); int rar[MAXCREG]; rl_p *lar; int maxindex; int regclass[NREGS]; struct perm *perms; struct perm * tuples(regls,nregneeded) rl_p *regls; { int class=0; register i,j; /* * First compute equivalence classes of registers. */ for (i=0;ip_next) { for (i=0; ip_rar[i]]) goto diff; for (i=0; ip_rar[i],pp->p_rar[j])) goto diff; return; diff: ; } pp = (struct perm *) myalloc(sizeof ( *pp )); pp->p_next = perms; for (i=0; ip_rar[i] = rar[i]; perms = pp; } else { rlp=lar[index]; for (i=rlp->rl_n-1; i>=0; i--) { rar[index] = rlp->rl_list[i]; permute(index+1); } } }