File: ClockGroups.hh

package info (click to toggle)
opensta 0~20191111gitc018cb2%2Bdfsg-1.1
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 5,128 kB
  • sloc: cpp: 99,118; tcl: 8,530; yacc: 1,435; lex: 894; makefile: 541; sh: 107
file content (71 lines) | stat: -rw-r--r-- 2,004 bytes parent folder | download | duplicates (2)
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
// OpenSTA, Static Timing Analyzer
// Copyright (c) 2019, Parallax Software, Inc.
// 
// This program 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.
// 
// This program 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 <https://www.gnu.org/licenses/>.

#ifndef STA_CLOCK_GROUPS_H
#define STA_CLOCK_GROUPS_H

#include "DisallowCopyAssign.hh"
#include "SdcCmdComment.hh"
#include "SdcClass.hh"

namespace sta {

class ClockGroup
{
public:
  ClockGroup(ClockSet *clks);
  ~ClockGroup();
  bool isMember(const Clock *clk);
  ClockSet *clks() const { return clks_; }

private:
  DISALLOW_COPY_AND_ASSIGN(ClockGroup);

  ClockSet *clks_;
};

class ClockGroups : public SdcCmdComment
{
public:
  ClockGroups(const char *name,
	      bool logically_exclusive,
	      bool physically_exclusive,
	      bool asynchronous,
	      bool allow_paths,
	      const char *comment);
  ~ClockGroups();
  ClockGroup *makeClockGroup(ClockSet *clks);
  const char *name() const { return name_; }
  ClockGroupSet *groups() { return &groups_; }
  bool logicallyExclusive() const { return logically_exclusive_; }
  bool physicallyExclusive() const { return physically_exclusive_; }
  bool asynchronous() const { return asynchronous_; }
  bool allowPaths() const { return allow_paths_; }
  void removeClock(Clock *clk);

private:
  const char *name_;
  bool logically_exclusive_;
  bool physically_exclusive_;
  bool asynchronous_;
  bool allow_paths_;
  ClockGroupSet groups_;

  DISALLOW_COPY_AND_ASSIGN(ClockGroups);
};

} // namespace
#endif