diff options
| author | Eddie Hung <eddieh@ece.ubc.ca> | 2018-08-06 17:20:29 -0700 | 
|---|---|---|
| committer | Eddie Hung <eddieh@ece.ubc.ca> | 2018-08-06 17:20:29 -0700 | 
| commit | 483f8631068086d7f0bdf10f60205567e03d943e (patch) | |
| tree | 433739d73a91f29752bb3e5bd0d6b68b6d07c5d4 | |
| parent | 6768a5c03e59e75ac20c666419b4e42cc16118e1 (diff) | |
| download | nextpnr-483f8631068086d7f0bdf10f60205567e03d943e.tar.gz nextpnr-483f8631068086d7f0bdf10f60205567e03d943e.tar.bz2 nextpnr-483f8631068086d7f0bdf10f60205567e03d943e.zip | |
Also add PLL outputs as timing startpoints
| -rw-r--r-- | common/timing.cc | 18 | 
1 files changed, 3 insertions, 15 deletions
| diff --git a/common/timing.cc b/common/timing.cc index b1be8dad..3a4f0f9c 100644 --- a/common/timing.cc +++ b/common/timing.cc @@ -61,7 +61,7 @@ struct Timing          // First, compute the topographical order of nets to walk through          //   the circuit, assuming it is a _acyclic_ graph -        //   TODO: Handle the case where it is cyclic, e.g. combinatorial loops +        //   TODO(eddieh): Handle the case where it is cyclic, e.g. combinatorial loops          std::vector<NetInfo*> topographical_order;          std::unordered_map<const NetInfo*, TimingData> net_data;          // In lieu of deleting edges from the graph, simply count @@ -94,7 +94,8 @@ struct Timing                  }                  else {                      // Also add I/O cells too -                    if (is_io) { +                                                      // TODO(eddieh): More generic way of detecting PLLs +                    if (is_io || cell.second->type == ctx->id("ICESTORM_PLL")) {                          topographical_order.emplace_back(o->net);                          net_data.emplace(o->net, TimingData{});                      } @@ -157,22 +158,9 @@ struct Timing              }          } -#if 0          // Sanity check to ensure that all ports where fanins were recorded          //   were indeed visited -        log_info("port_fanin = %d\n", port_fanin.size()); -        for (auto i : port_fanin) { -            log_info("%s %s.%s has %d fanins left\n", i.first->net->name.c_str(ctx),i.first->net->driver.cell->name.c_str(ctx), i.first->name.c_str(ctx), i.second); -            auto cell = i.first->net->driver.cell; -            for (auto& port : cell->ports) { -                if (!port.second.net) continue; -                if (port.second.type == PORT_IN) -                    log_info("    %s connected to %s\n", port.second.name.c_str(ctx), port.second.net->name.c_str(ctx)); -            } -        }          NPNR_ASSERT(port_fanin.empty()); -#endif -        port_fanin.clear();          // Go forwards topographically to find the maximum arrival time          //   and max path length for each net | 
