HAL
gatelibrary_tab_truth_table.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 "
gatelibrary_tab_interface.h
"
29
#include "
hal_core/defines.h
"
30
#include "
hal_core/netlist/gate_library/gate_type.h
"
31
#include "
hal_core/netlist/gate.h
"
32
33
#include <QFormLayout>
34
#include <QLabel>
35
#include <QTableWidget>
36
#include <QHeaderView>
37
#include "
gui/gatelibrary_management/gatelibrary_frames/gatelibrary_component_frame.h
"
38
39
namespace
hal
40
{
41
class
GatelibraryLutInit
:
public
GatelibraryComponentFrame
42
{
43
Q_OBJECT
44
45
QLineEdit
* mEdit;
46
47
Q_SIGNALS
:
48
void
initValueChanged
(
u64
initValue);
49
50
private
Q_SLOTS
:
51
void
handleTextChanged(
const
QString
& txt);
52
53
public
:
54
GatelibraryLutInit
(
QWidget
*
parent
=
nullptr
);
55
void
update
(
GateType
*gt)
override
;
56
};
57
61
class
GateLibraryTabTruthTable
:
public
GateLibraryTabInterface
62
{
63
Q_OBJECT
64
65
public
:
66
GateLibraryTabTruthTable
(
QWidget
*
parent
=
nullptr
);
67
68
void
update
(
GateType
* gt)
override
;
69
70
private
Q_SLOTS
:
71
void
handleLutInitValueChanged(
u64
initValue);
72
73
private
:
74
75
QGridLayout
* mLayout;
76
GatelibraryLutInit
* mLutInit;
77
QTableWidget
* mTableWidget;
78
QHeaderView
* mHeaderView;
79
QLabel
* mDisclaimer;
80
GateType
* mGateType;
81
82
void
setTableSize();
83
int
getRowNumber()
const
;
84
int
getColumnNumber()
const
;
85
bool
updateFlipFlop();
86
void
updateLookupTable();
87
bool
setCellValue(
int
irow,
int
icol,
BooleanFunction::Value
bfval);
88
};
89
90
}
hal::BooleanFunction::Value
Value
represents the type of the node
Definition:
boolean_function.h:74
hal::GateLibraryTabInterface
Definition:
gatelibrary_tab_interface.h:39
hal::GateLibraryTabTruthTable
Definition:
gatelibrary_tab_truth_table.h:62
hal::GateLibraryTabTruthTable::GateLibraryTabTruthTable
GateLibraryTabTruthTable(QWidget *parent=nullptr)
Definition:
gatelibrary_tab_truth_table.cpp:12
hal::GateType
Definition:
gate_type.h:52
hal::GatelibraryComponentFrame
Definition:
gatelibrary_component_frame.h:38
hal::GatelibraryLutInit
Definition:
gatelibrary_tab_truth_table.h:42
hal::GatelibraryLutInit::GatelibraryLutInit
GatelibraryLutInit(QWidget *parent=nullptr)
Definition:
gatelibrary_tab_truth_table.cpp:421
hal::GatelibraryLutInit::initValueChanged
void initValueChanged(u64 initValue)
defines.h
u64
uint64_t u64
Definition:
defines.h:42
gate.h
gate_type.h
gatelibrary_component_frame.h
gatelibrary_tab_interface.h
hal
Definition:
parser_liberty.cpp:10
QGridLayout
QHeaderView
QLabel
QLineEdit
QObject::Q_OBJECT
Q_OBJECTQ_OBJECT
QObject::Q_SIGNALS
Q_SIGNALSQ_SIGNALS
QObject::Q_SLOTS
Q_SLOTSQ_SLOTS
QObject::parent
QObject * parent() const const
QString
QTableWidget
QWidget
QWidget::update
void update()
plugins
gui
include
gui
gatelibrary_management
gatelibrary_tab_widgets
gatelibrary_tab_truth_table.h
Generated on Fri Feb 14 2025 14:22:41 for HAL by
1.9.1