FreeCalypso > hg > ueda-linux
view ueda/sverp-bind/outcomp.c @ 71:a3d47129ebdc
pads2gpcb: implemented mirroring and rotation of instantiated parts
author | Mychaela Falconia <falcon@ivan.Harhan.ORG> |
---|---|
date | Mon, 01 Feb 2016 00:13:20 +0000 |
parents | c59f52e4bacf |
children |
line wrap: on
line source
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <strings.h> #include "../libueda/mcl.h" #include "../libueda/xga.h" #include "struct.h" extern struct component components[]; extern int ncomponents; extern char *get_comp_attr(); extern struct grid_pkg_desc *read_grid_pkg_file(); extern int check_completeness; struct outcomp *netlist_comps; static int try_numpins(oc) register struct outcomp *oc; { char *npins_attr; register int n; npins_attr = get_comp_attr(oc->mclcomp, "npins"); if (!npins_attr) return(0); n = atoi(npins_attr); if (n <= 0) { fprintf(stderr, "component %s: invalid npins attribute\n", oc->name); exit(1); } oc->npins = n; return(1); } static int try_gridpkg(oc) register struct outcomp *oc; { char *attr; register struct grid_pkg_desc *desc; attr = get_comp_attr(oc->mclcomp, "grid_pkg"); if (!attr) return(0); desc = read_grid_pkg_file(attr); oc->grid_pkg = desc; oc->npins = desc->nrows * desc->ncolumns; return(1); } static void init_one_outcomp(oc) register struct outcomp *oc; { register struct pinconn **conn_array; register char *attr; oc->name = oc->mclcomp->name; try_numpins(oc); if (!oc->npins) try_gridpkg(oc); if (!oc->npins) { fprintf(stderr, "error: %s has neither npins nor grid_pkg attribute\n", oc->name); exit(1); } conn_array = (struct pinconn **) malloc(sizeof(struct pinconn *) * oc->npins); if (!conn_array) { perror("malloc"); exit(1); } bzero(conn_array, sizeof(struct pinconn *) * oc->npins); oc->conn_array = conn_array; if (attr = get_comp_attr(oc->mclcomp, "hier")) process_hier_attr(oc, attr); else if (attr = get_comp_attr(oc->mclcomp, "slotmap")) process_slotmap_attr(oc, attr); else if (check_completeness) fprintf(stderr, "MCL component %s has no binding\n", oc->name); } init_outcomp_from_MCL() { register int i; netlist_comps = (struct outcomp *) malloc(sizeof(struct outcomp) * ncomponents); if (!netlist_comps) { perror("malloc"); exit(1); } bzero(netlist_comps, sizeof(struct outcomp) * ncomponents); for (i = 0; i < ncomponents; i++) { netlist_comps[i].mclcomp = components + i; init_one_outcomp(netlist_comps + i); } }