HAL
hgl_parser.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/defines.h"
31 #include "rapidjson/document.h"
32 
33 #include <filesystem>
34 #include <map>
35 #include <optional>
36 #include <unordered_map>
37 
38 namespace hal
39 {
44  {
45  public:
46  HGLParser() = default;
47  ~HGLParser() = default;
48 
55  Result<std::unique_ptr<GateLibrary>> parse(const std::filesystem::path& file_path) override;
56 
57  private:
58  const u32 HGL_FORMAT_VERSION = 4;
59  u32 file_version = 1;
60 
61  struct PinCtx
62  {
63  std::vector<std::string> pins;
64  std::unordered_map<std::string, PinType> pin_to_type;
65  std::unordered_map<std::string, PinDirection> pin_to_direction;
66  std::unordered_map<std::string, std::string> boolean_functions;
67  };
68 
69  struct GroupCtx
70  {
71  std::vector<std::string> pins;
72  bool ascending;
74  };
75 
76  std::unique_ptr<GateLibrary> m_gate_lib;
77  std::filesystem::path m_path;
78 
79  std::set<std::string> m_cell_names;
80 
81  Result<std::monostate> parse_gate_library(const rapidjson::Document& document);
82  Result<std::monostate> parse_gate_type(const rapidjson::Value& gate_type);
83  Result<std::monostate> parse_pin(PinCtx& pin_ctx, const rapidjson::Value& pin);
84  Result<std::unique_ptr<GateTypeComponent>> parse_lut_config(const rapidjson::Value& lut_config);
85  Result<std::unique_ptr<GateTypeComponent>> parse_ff_config(const rapidjson::Value& ff_config);
86  Result<std::unique_ptr<GateTypeComponent>> parse_latch_config(const rapidjson::Value& latch_config);
87  Result<std::unique_ptr<GateTypeComponent>> parse_ram_config(const rapidjson::Value& ram_config);
88  };
89 } // namespace hal
#define NETLIST_API
Definition: arch_linux.h:30
HGLParser()=default
~HGLParser()=default
std::unique_ptr< GateLibrary > parse(std::filesystem::path file_path)
quint32 u32
std::vector< PinInformation > pins
u32 start_index
bool ascending