HAL
mac_component.h
Go to the documentation of this file.
1
// MIT License
2
//
3
// Copyright (c) 2019 Ruhr University Bochum, Chair for Embedded Security. All Rights reserved.
4
// Copyright (c) 2019 Marc Fyrbiak, Sebastian Wallat, Max Hoffmann ("ORIGINAL AUTHORS"). All rights reserved.
5
// Copyright (c) 2021 Max Planck Institute for Security and Privacy. All Rights reserved.
6
// Copyright (c) 2021 Jörn Langheinrich, Julian Speith, Nils Albartus, René Walendy, Simon Klix ("ORIGINAL AUTHORS"). All Rights reserved.
7
//
8
// Permission is hereby granted, free of charge, to any person obtaining a copy
9
// of this software and associated documentation files (the "Software"), to deal
10
// in the Software without restriction, including without limitation the rights
11
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
// copies of the Software, and to permit persons to whom the Software is
13
// furnished to do so, subject to the following conditions:
14
//
15
// The above copyright notice and this permission notice shall be included in all
16
// copies or substantial portions of the Software.
17
//
18
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
24
// SOFTWARE.
25
26
#pragma once
27
28
#include "
hal_core/netlist/gate_library/gate_type_component/gate_type_component.h
"
29
30
namespace
hal
31
{
32
class
MACComponent
:
public
GateTypeComponent
33
{
34
public
:
38
MACComponent
() =
default
;
39
45
ComponentType
get_type
()
const override
;
46
53
static
bool
is_class_of
(
const
GateTypeComponent
* component);
54
62
std::vector<GateTypeComponent*>
get_components
(
const
std::function<
bool
(
const
GateTypeComponent
*)>& filter =
nullptr
)
const override
;
63
64
private
:
65
static
constexpr
ComponentType
m_type =
ComponentType::mac
;
66
};
67
}
// namespace hal
hal::GateTypeComponent
Definition:
gate_type_component.h:40
hal::GateTypeComponent::ComponentType
ComponentType
Definition:
gate_type_component.h:48
hal::GateTypeComponent::ComponentType::mac
@ mac
hal::MACComponent
Definition:
mac_component.h:33
hal::MACComponent::is_class_of
static bool is_class_of(const GateTypeComponent *component)
Definition:
mac_component.cpp:10
hal::MACComponent::get_components
std::vector< GateTypeComponent * > get_components(const std::function< bool(const GateTypeComponent *)> &filter=nullptr) const override
Definition:
mac_component.cpp:15
hal::MACComponent::get_type
ComponentType get_type() const override
Definition:
mac_component.cpp:5
hal::MACComponent::MACComponent
MACComponent()=default
gate_type_component.h
hal
Definition:
parser_liberty.cpp:10
include
hal_core
netlist
gate_library
gate_type_component
mac_component.h
Generated on Tue Oct 21 2025 12:17:32 for HAL by
1.9.1