aboutsummaryrefslogtreecommitdiffstats
path: root/src/lib/evtimer.h
blob: 7b2e01c6d80757814dd8d04e6c3456d284070db9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
    ChibiOS/RT - Copyright (C) 2006-2007 Giovanni Di Sirio.

    This file is part of ChibiOS/RT.

    ChibiOS/RT is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 3 of the License, or
    (at your option) any later version.

    ChibiOS/RT is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

/**
 * @file evtimer.h
 * @{
 * Event Timer definitions.
 * @see evtimer.c
 */

#ifndef _EVTIMER_H_
#define _EVTIMER_H_


typedef struct {
  VirtualTimer  et_vt;
  EventSource   et_es;
  systime_t     et_interval;
} EvTimer;

#ifdef __cplusplus
extern "C" {
#endif
  void evtStart(EvTimer *etp);
  void evtStop(EvTimer *etp);
#ifdef __cplusplus
}
#endif

/**
 * Initializes an \p EvTimer structure.
 */
#define evtInit(etp, i) (chEvtInit(&(etp)->et_es), \
                        (etp)->et_vt.vt_func = NULL, \
                        (etp)->et_interval = (i))

#endif /* _EVTIMER_H_ */

/** @} */
rtInfo &rep = rep_cell->ports.at(rep_name); NPNR_ASSERT(old.type == rep.type); rep.net = old.net; old.net = nullptr; if (rep.type == PORT_OUT) { if (rep.net != nullptr) { rep.net->driver.cell = rep_cell; rep.net->driver.port = rep_name; } } else if (rep.type == PORT_IN) { if (rep.net != nullptr) { for (PortRef &load : rep.net->users) { if (load.cell == old_cell && load.port == old_name) { load.cell = rep_cell; load.port = rep_name; } } } } else { NPNR_ASSERT(false); } } // Print utilisation of a design void print_utilisation(const Context *ctx) { // Sort by Bel type std::map<BelType, int> used_types; for (auto &cell : ctx->cells) { used_types[ctx->belTypeFromId(cell.second.get()->type)]++; } std::map<BelType, int> available_types; for (auto bel : ctx->getBels()) { available_types[ctx->getBelType(bel)]++; } log_break(); log_info("Device utilisation:\n"); for (auto type : available_types) { IdString type_id = ctx->belTypeToId(type.first); int used_bels = get_or_default(used_types, type.first, 0); log_info("\t%20s: %5d/%5d %5d%%\n", type_id.c_str(ctx), used_bels, type.second, 100 * used_bels / type.second); } log_break(); } NEXTPNR_NAMESPACE_END