-
Notifications
You must be signed in to change notification settings - Fork 706
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
vendor: import the HPDcache sources into the vendor subtree
Signed-off-by: Cesar Fuguet <[email protected]>
- Loading branch information
Cesar Fuguet
committed
Oct 8, 2023
1 parent
cce022f
commit c8d518a
Showing
84 changed files
with
25,376 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
vnc_logs/ | ||
veloce.map | ||
VRMDATA/ | ||
*.log | ||
*.wlf | ||
*.ucdb |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
# Changelog | ||
All notable changes to this project will be documented in this file. | ||
|
||
The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) | ||
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html). | ||
|
||
## [Unreleased] | ||
|
||
### Added | ||
|
||
### Removed | ||
|
||
### Changed | ||
|
||
### Fixed | ||
|
||
## [3.0.0] 2023-10-08 | ||
|
||
### Added | ||
|
||
- Add support for virtually-indexed addressing | ||
|
||
### Fixed | ||
|
||
- Fix forwarding logic of uncacheable Icache response in the cva6 cache subsystem. | ||
- Fix wrong mask signal when implementing the MSHR in registers | ||
|
||
## [2.1.0] - 2023-09-25 | ||
|
||
### Added | ||
|
||
- Add additional configuration to implement MSHR in registers (when the number | ||
of entries is low) | ||
|
||
### Fixed | ||
|
||
- Fix cache data SRAM chip-select generation when word width is different than | ||
64 bits (e.g. 32 bits) | ||
|
||
## [2.0.0] - 2023-09-18 | ||
|
||
### Added | ||
|
||
- Add parameters in the HPDcache module to define the types of interfaces to | ||
the memory | ||
- Add helper verilog header file with macros to ease the type definition of | ||
interfaces to the memory | ||
- Add new event signals in the HPDCache top module | ||
- Add generic single-port RAM macros with byte-enable signals | ||
- Add parameters in the package to choose between RAM macros implementing | ||
byte-enable or bitmask for the different RAMs instances | ||
- Add additional assertions to verify parameters | ||
- Add additional configuration signal to inhibit write coalescing in the write | ||
buffer | ||
|
||
### Removed | ||
|
||
- Remove base_id ports in the HPDCache top module | ||
- Remove nettype (wire,var) in ports as it looks like is badly supported in | ||
some cases by some simulation tools | ||
|
||
### Changed | ||
|
||
- Split the hpdcache_pkg into: (1) the hpdcache_pkg contains internally defined | ||
parameters; (2) a new hpdcache_params_pkg that defines user parameters | ||
- New selection policy of ready requests in the replay table. It gives priority | ||
to requests in the same linked list. | ||
- The write buffer now accepts writes from requesters in a pending slot when it | ||
is waiting for the internal arbiter to forward the data to the NoC. | ||
|
||
### Fixed | ||
|
||
- Correctly support HPDCACHE_ACCESS_WORDS=1 | ||
- Correctly support HPDCACHE_ACCESS_WORDS=HPDCACHE_CL_WORDS | ||
- Fix width of the nlines count register in the HW memory prefetcher. | ||
|
||
## [1.0.0] - 2023-02-22 | ||
|
||
### Added | ||
- Initial release to the OpenHW Group |
Validating CODEOWNERS rules …
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
# Global Owners | ||
* @cfuguet |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
Solderpad Hardware License v2.1 | ||
|
||
This license operates as a wraparound license to the Apache License | ||
Version 2.0 (the “Apache License”) and incorporates the terms and | ||
conditions of the Apache License (which can be found here: | ||
http://apache.org/licenses/LICENSE-2.0), with the following additions and | ||
modifications. It must be read in conjunction with the Apache License. | ||
Section 1 below modifies definitions and terminology in the Apache | ||
License and Section 2 below replaces Section 2 of the Apache License. | ||
The Appendix replaces the Appendix in the Apache License. You may, at | ||
your option, choose to treat any Work released under this license as | ||
released under the Apache License (thus ignoring all sections written | ||
below entirely). | ||
|
||
1. Terminology in the Apache License is supplemented or modified as | ||
follows: | ||
|
||
“Authorship”: any reference to ‘authorship’ shall be taken to read | ||
“authorship or design”. | ||
|
||
“Copyright owner”: any reference to ‘copyright owner’ shall be taken to | ||
read “Rights owner”. | ||
|
||
“Copyright statement”: the reference to ‘copyright statement’ shall be | ||
taken to read ‘copyright or other statement pertaining to Rights’. | ||
|
||
The following new definition shall be added to the Definitions section of | ||
the Apache License: | ||
|
||
“Rights” means copyright and any similar right including design right | ||
(whether registered or unregistered), rights in semiconductor | ||
topographies (mask works) and database rights (but excluding Patents and | ||
Trademarks). | ||
|
||
The following definitions shall replace the corresponding definitions in | ||
the Apache License: | ||
|
||
“License” shall mean this Solderpad Hardware License version 2.1, being | ||
the terms and conditions for use, manufacture, instantiation, adaptation, | ||
reproduction, and distribution as defined by Sections 1 through 9 of this | ||
document. | ||
|
||
“Licensor” shall mean the owner of the Rights or entity authorized by the | ||
owner of the Rights that is granting the License. | ||
|
||
“Derivative Works” shall mean any work, whether in Source or Object form, | ||
that is based on (or derived from) the Work and for which the editorial | ||
revisions, annotations, elaborations, or other modifications represent, | ||
as a whole, an original work of authorship or design. For the purposes of | ||
this License, Derivative Works shall not include works that remain | ||
reversibly separable from, or merely link (or bind by name) or physically | ||
connect to or interoperate with the Work and Derivative Works thereof. | ||
|
||
“Object” form shall mean any form resulting from mechanical | ||
transformation or translation of a Source form or the application of a | ||
Source form to physical material, including but not limited to compiled | ||
object code, generated documentation, the instantiation of a hardware | ||
design or physical object or material and conversions to other media | ||
types, including intermediate forms such as bytecodes, FPGA bitstreams, | ||
moulds, artwork and semiconductor topographies (mask works). | ||
|
||
“Source” form shall mean the preferred form for making modifications, | ||
including but not limited to source code, net lists, board layouts, CAD | ||
files, documentation source, and configuration files. | ||
|
||
“Work” shall mean the work of authorship or design, whether in Source or | ||
Object form, made available under the License, as indicated by a notice | ||
relating to Rights that is included in or attached to the work (an | ||
example is provided in the Appendix below). | ||
|
||
2. Grant of License. Subject to the terms and conditions of this License, | ||
each Contributor hereby grants to You a perpetual, worldwide, | ||
non-exclusive, no-charge, royalty-free, irrevocable license under the | ||
Rights to reproduce, prepare Derivative Works of, make, adapt, repair, | ||
publicly display, publicly perform, sublicense, and distribute the Work | ||
and such Derivative Works in Source or Object form and do anything in | ||
relation to the Work as if the Rights did not exist. | ||
|
||
APPENDIX | ||
|
||
Copyright 2023 CEA* | ||
*Commissariat a l'Energie Atomique et aux Energies Alternatives (CEA) | ||
|
||
SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1 | ||
|
||
Licensed under the Solderpad Hardware License v 2.1 (the “License”); you | ||
may not use this file except in compliance with the License, or, at your | ||
option, the Apache License version 2.0. You may obtain a copy of the | ||
License at | ||
|
||
https://solderpad.org/licenses/SHL-2.1/ | ||
|
||
Unless required by applicable law or agreed to in writing, any work | ||
distributed under the License is distributed on an “AS IS” BASIS, WITHOUT | ||
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||
License for the specific language governing permissions and limitations | ||
under the License. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
# OpenHW Core-V High-Performance L1 Dcache (CV-HPDcache) | ||
|
||
The HPDcache is an open-source High-Performance, Multi-requester, Out-of-Order L1 Dcache for RISC-V cores and accelerators. | ||
|
||
|
||
## Directory Structure | ||
|
||
<table> | ||
<tr> | ||
<th style="text-align:left;width:20%">Directory</th> | ||
<th style="text-align:left">Description</th> | ||
</tr> | ||
<tr> | ||
<td><i>rtl</i></td> | ||
<td>Contains the file lists to be used for the compiling of the HPDcache</td> | ||
</tr> | ||
<tr> | ||
<td><i>rtl/src<i></td> | ||
<td>Contains the SystemVerilog RTL sources of the HPDcache</td> | ||
</tr> | ||
<tr> | ||
<td><i>rtl/src/target</i></td> | ||
<td>Contains processor-dependent sources (e.g. adapter modules for the CVA6 core)</td> | ||
</tr> | ||
<tr> | ||
<td><i>docs</i></td> | ||
<td>Contains documentation of the HPDcache</td> | ||
</tr> | ||
</table> | ||
|
||
|
||
## Documentation | ||
|
||
The HPDcache specification document can be found in the *docs/hpdcache_spec_document* folder. | ||
It is written in LaTeX. | ||
You cand find pre-compiled PDF documents in *docs/hpdcache_spec_document/release*. | ||
|
||
If you need to recompile the specification document, a dedicated *Makefile* is in the specification folder. | ||
This *Makefile* needs the *latexmk* command-line tool (included in most common LaTeX distributions) and the *inkscape* tool to convert SVG images into PDF. | ||
|
||
|
||
## Licensing | ||
|
||
The HPDcache is released under the Solderpad Hardware License (version 2.1). | ||
Please refer to the [LICENSE](LICENSE) file for further information. |
3 changes: 3 additions & 0 deletions
3
vendor/openhwgroup/cvhpdcache/docs/hpdcache_spec_document/.gitignore
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
build/ | ||
pdf/ | ||
supplement/package |
122 changes: 122 additions & 0 deletions
122
vendor/openhwgroup/cvhpdcache/docs/hpdcache_spec_document/Makefile
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
## | ||
## Copyright 2023 CEA* | ||
## *Commissariat a l'Energie Atomique et aux Energies Alternatives (CEA) | ||
## | ||
## SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1 | ||
## | ||
## Licensed under the Solderpad Hardware License v 2.1 (the “License”); you | ||
## may not use this file except in compliance with the License, or, at your | ||
## option, the Apache License version 2.0. You may obtain a copy of the | ||
## License at | ||
## | ||
## https://solderpad.org/licenses/SHL-2.1/ | ||
## | ||
## Unless required by applicable law or agreed to in writing, any work | ||
## distributed under the License is distributed on an “AS IS” BASIS, WITHOUT | ||
## WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||
## License for the specific language governing permissions and limitations | ||
## under the License. | ||
## | ||
## Author(s): Cesar Fuguet | ||
## Date: February, 2023 | ||
## Description: Makefile for the specification document of the HPDcache | ||
## hardware IP | ||
## | ||
LATEXMK = latexmk -pdf | ||
INKSCAPE = inkscape --without-gui | ||
PDFVIEWER = evince | ||
RM = rm -rf | ||
RMDIR = rmdir -p | ||
CP = cp -f | ||
ECHO = echo -e | ||
MKDIR = mkdir -p | ||
|
||
PDF_DIR = pdf | ||
AUX_DIR = build | ||
SOURCE_DIR = source | ||
RELEASE_DIR = release | ||
|
||
VERSION = $(shell cat version) | ||
|
||
TARGET = hpdcache_spec | ||
TEX_SOURCES = $(SOURCE_DIR)/$(TARGET).bib \ | ||
$(SOURCE_DIR)/hpdcache_spec_changelog.tex \ | ||
$(SOURCE_DIR)/hpdcache_spec_preamble.tex \ | ||
$(AUX_DIR)/hpdcache_data_ram_organization.pdf \ | ||
$(AUX_DIR)/hpdcache_request_arbiter.pdf \ | ||
$(AUX_DIR)/hpdcache_core.pdf \ | ||
$(AUX_DIR)/hpdcache_request_address_data_alignment.pdf \ | ||
$(AUX_DIR)/hpdcache_data_ram_organization.emf \ | ||
$(AUX_DIR)/hpdcache_request_arbiter.emf \ | ||
$(AUX_DIR)/hpdcache_core.emf \ | ||
$(AUX_DIR)/hpdcache_request_address_data_alignment.emf \ | ||
$(AUX_DIR)/wave_ready_before_valid.pdf \ | ||
$(AUX_DIR)/wave_valid_before_ready.pdf \ | ||
$(AUX_DIR)/wave_ready_when_valid.pdf \ | ||
$(AUX_DIR)/wave_back_to_back.pdf \ | ||
$(AUX_DIR)/wave_ready_before_valid.emf \ | ||
$(AUX_DIR)/wave_valid_before_ready.emf \ | ||
$(AUX_DIR)/wave_ready_when_valid.emf \ | ||
$(AUX_DIR)/wave_back_to_back.emf | ||
|
||
LATEXMK_ARGS = -bibtex \ | ||
$(if $(VERBOSE),,-silent) \ | ||
-pretex='\newcommand{\docversion}{$(VERSION)}' \ | ||
-usepretex | ||
|
||
vpath %.svg $(SOURCE_DIR)/images | ||
vpath %.svg $(SOURCE_DIR)/images/exported | ||
|
||
all: | ||
@$(ECHO) "usage: make [target]\n" | ||
@$(ECHO) "Target candidates:\n" | ||
@$(ECHO) "pdf generate PDF document" | ||
@$(ECHO) "release make a release of the PDF document" | ||
@$(ECHO) "view view PDF document" | ||
@$(ECHO) "clean clean auxiliary files" | ||
@$(ECHO) "clean_pdf clean PDF file" | ||
@$(ECHO) "distclean clean all generated files" | ||
|
||
.PHONY: release | ||
release: $(RELEASE_DIR)/$(TARGET)-$(VERSION).pdf | ||
|
||
$(RELEASE_DIR)/$(TARGET)-$(VERSION).pdf: $(PDF_DIR)/$(TARGET).pdf | ||
@$(MKDIR) $(dir $@) | ||
$(CP) $< $@ | ||
|
||
.PHONY: pdf | ||
pdf: $(PDF_DIR)/$(TARGET).pdf | ||
|
||
$(PDF_DIR)/$(TARGET).pdf: $(AUX_DIR)/$(TARGET).pdf | ||
@$(MKDIR) $(dir $@) | ||
$(CP) $< $@ | ||
|
||
$(AUX_DIR)/$(TARGET).pdf: $(SOURCE_DIR)/$(TARGET).tex \ | ||
$(TEX_SOURCES) | ||
@$(MKDIR) $(dir $@) | ||
$(LATEXMK) $(LATEXMK_ARGS) --output-directory=$(dir $@) $< | ||
|
||
$(AUX_DIR)/%.pdf: %.svg | ||
@$(MKDIR) $(dir $@) | ||
$(INKSCAPE) --export-pdf=$@ --export-area-drawing $< | ||
|
||
$(AUX_DIR)/%.emf: %.svg | ||
@$(MKDIR) $(dir $@) | ||
$(INKSCAPE) --export-emf=$@ --export-area-drawing $< | ||
|
||
.PHONY: view | ||
view: $(PDF_DIR)/$(TARGET).pdf | ||
@$(ECHO) "Opening PDF viewer..." | ||
@$(PDFVIEWER) $< >&/dev/null & | ||
|
||
.PHONY: clean clean_pdf distclean | ||
clean: | ||
@$(ECHO) "Cleaning build directory..." | ||
@$(RM) $(AUX_DIR) | ||
|
||
clean_pdf: | ||
@$(ECHO) "Cleaning generated PDF file..." | ||
@$(RM) $(PDF_DIR)/$(TARGET).pdf | ||
@$(RMDIR) $(PDF_DIR) >&/dev/null || true | ||
|
||
distclean: clean clean_pdf |
2 changes: 2 additions & 0 deletions
2
vendor/openhwgroup/cvhpdcache/docs/hpdcache_spec_document/latexmkrc
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
$ENV{'TEXINPUTS'}=':source:source/images:source/images/exported:build:'; | ||
$ENV{'BIBINPUTS'}=':source:'; |
Binary file added
BIN
+555 KB
.../openhwgroup/cvhpdcache/docs/hpdcache_spec_document/release/hpdcache_spec-1.0.0-draft.pdf
Binary file not shown.
Oops, something went wrong.