From 10ef9da67f10a22824f976105a0fa658173327b3 Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Fri, 7 Jan 2022 14:37:59 -0800 Subject: [PATCH 01/75] Add docs-resources submodule Signed-off-by: Stephano Cetola --- .gitmodules | 3 +++ docs-resources | 1 + 2 files changed, 4 insertions(+) create mode 100644 .gitmodules create mode 160000 docs-resources diff --git a/.gitmodules b/.gitmodules new file mode 100644 index 00000000..cde1eb58 --- /dev/null +++ b/.gitmodules @@ -0,0 +1,3 @@ +[submodule "docs-resources"] + path = docs-resources + url = https://github.com/riscv/docs-resources.git diff --git a/docs-resources b/docs-resources new file mode 160000 index 00000000..84e9c0ac --- /dev/null +++ b/docs-resources @@ -0,0 +1 @@ +Subproject commit 84e9c0ac213026c30effaadc81a4f7c962c49268 From ad49c6e673cca48cf57ba5b471c31429773ba16a Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Fri, 7 Jan 2022 14:38:18 -0800 Subject: [PATCH 02/75] Add simple example document Signed-off-by: Stephano Cetola --- .github/workflows/build-pdf.yml | 57 ++++ Makefile | 21 ++ chapter2.adoc | 47 +++ dependencies/Gemfile | 14 + dependencies/README.md | 3 + dependencies/apt_packages.txt | 19 ++ dependencies/package.json | 7 + example-spec.pdf | Bin 0 -> 122011 bytes example.bib | 513 ++++++++++++++++++++++++++++++++ header.adoc | 40 +++ images/risc-v_logo.png | Bin 0 -> 21600 bytes intro.adoc | 15 + readme.adoc | 3 + 13 files changed, 739 insertions(+) create mode 100644 .github/workflows/build-pdf.yml create mode 100644 Makefile create mode 100644 chapter2.adoc create mode 100644 dependencies/Gemfile create mode 100644 dependencies/README.md create mode 100644 dependencies/apt_packages.txt create mode 100644 dependencies/package.json create mode 100644 example-spec.pdf create mode 100644 example.bib create mode 100644 header.adoc create mode 100644 images/risc-v_logo.png create mode 100644 intro.adoc create mode 100644 readme.adoc diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml new file mode 100644 index 00000000..b1d0ce88 --- /dev/null +++ b/.github/workflows/build-pdf.yml @@ -0,0 +1,57 @@ +# This workflow installs dependencies for PDF generation, generates the PDF, +# and uploads the PDF as an artifact. + +name: Build Document PDF + +on: + push: + branches: [ $default-branch ] + pull_request: + branches: [ $default-branch ] + workflow_dispatch: + +jobs: + build: + runs-on: ubuntu-latest + + env: + APT_PACKAGES_FILE: ${{ github.workspace }}/dependencies/apt_packages.txt + BUNDLE_GEMFILE: ${{ github.workspace }}/dependencies/Gemfile + BUNDLE_BIN: ${{ github.workspace }}/bin + NPM_PACKAGE_FOLDER: ${{ github.workspace }}/dependencies + PDF_RESULT: example.pdf + steps: + - uses: actions/checkout@v2 + - name: Install Ubuntu packages + run: | + sudo apt-get update + grep -vE '^#' ${APT_PACKAGES_FILE} | xargs sudo apt-get install --yes --no-install-recommends + # Ruby for asciidoctor + - name: Setup Ruby and Gemfile content + uses: ruby/setup-ruby@v1 + with: + ruby-version: "2.6" + bundler-cache: true + # Node.js for wavedrom + - uses: actions/cache@v2 + with: + path: ~/.npm + key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} + restore-keys: | + ${{ runner.os }}-node- + - name: Setup Node.js + uses: actions/setup-node@v2 + with: + node-version: '14' + - name: Install Node.js dependencies + run: npm install ${NPM_PACKAGE_FOLDER} + - name: Generate PDF + run: | + PATH=${PATH}:${BUNDLE_BIN}:$(npm bin) \ + make ${PDF_RESULT} + - name: Archive PDF result + uses: actions/upload-artifact@v2 + with: + name: result.pdf + path: ${{ env.PDF_RESULT }} + retention-days: 7 diff --git a/Makefile b/Makefile new file mode 100644 index 00000000..1aad8f4e --- /dev/null +++ b/Makefile @@ -0,0 +1,21 @@ +HEADER_SOURCE := header.adoc +PDF_RESULT := example-spec.pdf + +all: build + +build: + + @echo "Building asciidoc" + asciidoctor-pdf \ + --attribute=mathematical-format=svg \ + --attribute=pdf-fontsdir=docs-resources/fonts \ + --attribute=pdf-style=docs-resources/themes/riscv-pdf.yml \ + --failure-level=ERROR \ + --require=asciidoctor-bibtex \ + --require=asciidoctor-diagram \ + --require=asciidoctor-mathematical \ + --out-file=$(PDF_RESULT) \ + $(HEADER_SOURCE) + +clean: + rm example-spec.pdf diff --git a/chapter2.adoc b/chapter2.adoc new file mode 100644 index 00000000..f6f0995b --- /dev/null +++ b/chapter2.adoc @@ -0,0 +1,47 @@ +[[chapter2]] +== The Second Chapter + +. The first item. + +. The second item. ++ +.. The first sub item. + +.. The second sub item. ++ +[CAUTION] +==== +A moment of caution is required for this block of text must be read and apreciated for its importance. +==== + +. Yet another item. + +. Again, an item. + +.. A multi-line item. ++ +This item has multiple lines. ++ +By multiple lines, this is what we mean. ++ +Seriously, multiple. + +=== An example table + +[cols="^1,^1,^1,^1,^3,^3",stripes=even,options="header"] +|=== +4+|Letters _and_ bits {set:cellbgcolor:green} 2+|A much longer area +|L|R|W|X|Quarter 1|Quarter 2 +|{set:cellbgcolor:!} 0|0|0|0 2+|Rows alternate colors +|0|0|0|1|Thing 1|Thing 2 +|1|0|0|0|Thing 3|Thing 4 +|1|1|1|1 2+|Span Thing 1 and 2 +|=== + +=== Sub section + +Diam donec adipiscing tristique risus. Nisl rhoncus mattis rhoncus urna. Egestas egestas fringilla phasellus faucibus scelerisque eleifend donec pretium vulputate. Porta non pulvinar neque laoreet suspendisse interdum consectetur libero id. Massa vitae tortor condimentum lacinia quis vel. Donec ac odio tempor orci. Mi sit amet mauris commodo quis imperdiet massa tincidunt. Quis enim lobortis scelerisque fermentum dui. Lacus viverra vitae congue eu. Sed faucibus turpis in eu mi bibendum neque. Sit amet porttitor eget dolor. Aliquet eget sit amet tellus cras adipiscing enim. Id cursus metus aliquam eleifend mi. Vestibulum lorem sed risus ultricies tristique nulla aliquet. + +=== Yet another subsection + +Quam lacus suspendisse faucibus interdum posuere lorem ipsum. Nulla aliquet enim tortor at auctor urna nunc id cursus. Massa massa ultricies mi quis hendrerit dolor magna. Integer enim neque volutpat ac tincidunt. Dolor magna eget est lorem ipsum dolor. Urna neque viverra justo nec. Neque gravida in fermentum et. Fringilla ut morbi tincidunt augue interdum velit euismod. Dolor sit amet consectetur adipiscing elit. Eu facilisis sed odio morbi. In cursus turpis massa tincidunt dui. Orci phasellus egestas tellus rutrum tellus. Semper eget duis at tellus at urna condimentum. Orci porta non pulvinar neque laoreet suspendisse interdum consectetur. diff --git a/dependencies/Gemfile b/dependencies/Gemfile new file mode 100644 index 00000000..8cf7a50e --- /dev/null +++ b/dependencies/Gemfile @@ -0,0 +1,14 @@ +source 'https://rubygems.org' +gem 'asciidoctor' +gem 'asciidoctor-bibtex' +gem 'asciidoctor-diagram' +gem 'asciidoctor-mathematical' +gem 'asciidoctor-pdf' +gem 'citeproc-ruby' +gem 'coderay' +gem 'csl-styles' +gem 'json' +gem 'pygments.rb' +gem 'rghost' +gem 'rouge' +gem 'ruby_dev' diff --git a/dependencies/README.md b/dependencies/README.md new file mode 100644 index 00000000..0841ce89 --- /dev/null +++ b/dependencies/README.md @@ -0,0 +1,3 @@ +Dependencies for the build environment for various package managers. Used in +`.github/workflows/`. + diff --git a/dependencies/apt_packages.txt b/dependencies/apt_packages.txt new file mode 100644 index 00000000..378b1351 --- /dev/null +++ b/dependencies/apt_packages.txt @@ -0,0 +1,19 @@ +bison +build-essential +cmake +curl +flex +fonts-lyx +git +graphviz +# For wavedrom +default-jre +libcairo2-dev +libffi-dev +libgdk-pixbuf2.0-dev +libpango1.0-dev +libxml2-dev +make +pkg-config +ruby +ruby-dev diff --git a/dependencies/package.json b/dependencies/package.json new file mode 100644 index 00000000..9d80afe6 --- /dev/null +++ b/dependencies/package.json @@ -0,0 +1,7 @@ +{ + "name": "local", + "version": "0.0.1", + "dependencies": { + "wavedrom-cli": "^2.6.8" + } +} diff --git a/example-spec.pdf b/example-spec.pdf new file mode 100644 index 0000000000000000000000000000000000000000..2fe1b421d7915c9e237e731b82c010fd9d6043a6 GIT binary patch literal 122011 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 r;84alV}43Y!EmH`agsAS8+rL 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�|IW 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 literal 0 HcmV?d00001 diff --git a/intro.adoc b/intro.adoc new file mode 100644 index 00000000..66b71aa1 --- /dev/null +++ b/intro.adoc @@ -0,0 +1,15 @@ +[[intro]] +== Introduction + +Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do *eiusmod tempor* incididunt ut labore et dolore magna aliqua. Felis imperdiet proin fermentum leo vel orci porta. Volutpat lacus laoreet non curabitur gravida. Posuere urna nec tincidunt praesent semper feugiat nibh. Elit ``ullamcorper`` dignissim cras tincidunt lobortis. Malesuada fames ac turpis egestas integer eget. Tristique sollicitudin nibh sit amet commodo. Sed felis eget velit aliquet. Sit amet aliquam id diam maecenas ultricies mi. Consectetur purus ut faucibus pulvinar. Lectus urna duis convallis convallis tellus id. Fermentum iaculis eu non diam. Feugiat in fermentum posuere urna nec tincidunt praesent semper feugiat. Urna nec tincidunt praesent semper feugiat nibh. + +Commodo viverra maecenas accumsan lacus. Vulputate odio ut enim blandit volutpat maecenas volutpat blandit. Urna porttitor rhoncus dolor purus non. Tellus mauris a diam maecenas sed. Vitae auctor eu augue ut lectus. Ridiculus mus mauris vitae ultricies leo integer. Consequat semper viverra nam *libero* justo laoreet sit amet. Pellentesque pulvinar pellentesque habitant morbi tristique senectus et netus et. Ac placerat vestibulum lectus mauris ``ultrices`` eros in cursus turpis. Accumsan in nisl nisi scelerisque eu ultrices vitae. Cras ornare arcu dui vivamus. Vitae congue mauris rhoncus aenean. Consequat mauris nunc congue nisi vitae suscipit tellus. Tempus egestas sed sed risus pretium quam vulputate dignissim. Quis varius quam quisque id diam vel. Mattis nunc sed blandit libero volutpat sed cras ornare arcu. Amet mauris commodo quis imperdiet massa tincidunt nunc. + +[NOTE] +==== +Fames ac turpis egestas sed tempus urna et. Consequat nisl vel pretium lectus quam id leo in vitae. Velit scelerisque in dictum non. Eu volutpat odio facilisis mauris sit. +==== + +=== Sub Section of Introduction + +Pellentesque habitant morbi *tristique* senectus et netus et. Aliquam purus sit amet luctus. Odio eu ``feugiat`` pretium nibh ipsum consequat nisl vel. Euismod lacinia at quis risus sed vulputate odio ut. Eu sem integer vitae justo eget. Cursus euismod quis viverra nibh. Tempus egestas sed sed risus. Quis imperdiet massa tincidunt nunc pulvinar. Id venenatis a condimentum vitae sapien pellentesque habitant. diff --git a/readme.adoc b/readme.adoc new file mode 100644 index 00000000..ea89e845 --- /dev/null +++ b/readme.adoc @@ -0,0 +1,3 @@ += RISC-V docs-spec-template + +A template for building RISC-V specifications. From 118de3b1ce66640310ff5088c87f00937d04ce18 Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Fri, 7 Jan 2022 14:41:40 -0800 Subject: [PATCH 03/75] Update workflow Signed-off-by: Stephano Cetola --- .github/workflows/build-pdf.yml | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index b1d0ce88..9f0569da 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -19,9 +19,11 @@ jobs: BUNDLE_GEMFILE: ${{ github.workspace }}/dependencies/Gemfile BUNDLE_BIN: ${{ github.workspace }}/bin NPM_PACKAGE_FOLDER: ${{ github.workspace }}/dependencies - PDF_RESULT: example.pdf steps: - - uses: actions/checkout@v2 + - name: Checkout repository + uses: actions/checkout@v2 + with: + submodules: 'true' - name: Install Ubuntu packages run: | sudo apt-get update @@ -48,10 +50,10 @@ jobs: - name: Generate PDF run: | PATH=${PATH}:${BUNDLE_BIN}:$(npm bin) \ - make ${PDF_RESULT} + make - name: Archive PDF result uses: actions/upload-artifact@v2 with: - name: result.pdf - path: ${{ env.PDF_RESULT }} + name: example-spec.pdf + path: example-spec.pdf retention-days: 7 From 38faceab2e5cf4fdc0ab526fd52ab6d16cac590e Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Fri, 7 Jan 2022 14:55:37 -0800 Subject: [PATCH 04/75] Add a license file Signed-off-by: Stephano Cetola --- LICENSE | 396 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 396 insertions(+) create mode 100644 LICENSE diff --git a/LICENSE b/LICENSE new file mode 100644 index 00000000..53883b1c --- /dev/null +++ b/LICENSE @@ -0,0 +1,396 @@ +Attribution 4.0 International + +======================================================================= + +Creative Commons Corporation ("Creative Commons") is not a law firm and +does not provide legal services or legal advice. Distribution of +Creative Commons public licenses does not create a lawyer-client or +other relationship. Creative Commons makes its licenses and related +information available on an "as-is" basis. Creative Commons gives no +warranties regarding its licenses, any material licensed under their +terms and conditions, or any related information. Creative Commons +disclaims all liability for damages resulting from their use to the +fullest extent possible. + +Using Creative Commons Public Licenses + +Creative Commons public licenses provide a standard set of terms and +conditions that creators and other rights holders may use to share +original works of authorship and other material subject to copyright +and certain other rights specified in the public license below. The +following considerations are for informational purposes only, are not +exhaustive, and do not form part of our licenses. + + Considerations for licensors: Our public licenses are + intended for use by those authorized to give the public + permission to use material in ways otherwise restricted by + copyright and certain other rights. Our licenses are + irrevocable. Licensors should read and understand the terms + and conditions of the license they choose before applying it. + Licensors should also secure all rights necessary before + applying our licenses so that the public can reuse the + material as expected. Licensors should clearly mark any + material not subject to the license. This includes other CC- + licensed material, or material used under an exception or + limitation to copyright. More considerations for licensors: + wiki.creativecommons.org/Considerations_for_licensors + + Considerations for the public: By using one of our public + licenses, a licensor grants the public permission to use the + licensed material under specified terms and conditions. If + the licensor's permission is not necessary for any reason--for + example, because of any applicable exception or limitation to + copyright--then that use is not regulated by the license. Our + licenses grant only permissions under copyright and certain + other rights that a licensor has authority to grant. Use of + the licensed material may still be restricted for other + reasons, including because others have copyright or other + rights in the material. A licensor may make special requests, + such as asking that all changes be marked or described. + Although not required by our licenses, you are encouraged to + respect those requests where reasonable. More_considerations + for the public: + wiki.creativecommons.org/Considerations_for_licensees + +======================================================================= + +Creative Commons Attribution 4.0 International Public License + +By exercising the Licensed Rights (defined below), You accept and agree +to be bound by the terms and conditions of this Creative Commons +Attribution 4.0 International Public License ("Public License"). To the +extent this Public License may be interpreted as a contract, You are +granted the Licensed Rights in consideration of Your acceptance of +these terms and conditions, and the Licensor grants You such rights in +consideration of benefits the Licensor receives from making the +Licensed Material available under these terms and conditions. + + +Section 1 -- Definitions. + + a. Adapted Material means material subject to Copyright and Similar + Rights that is derived from or based upon the Licensed Material + and in which the Licensed Material is translated, altered, + arranged, transformed, or otherwise modified in a manner requiring + permission under the Copyright and Similar Rights held by the + Licensor. For purposes of this Public License, where the Licensed + Material is a musical work, performance, or sound recording, + Adapted Material is always produced where the Licensed Material is + synched in timed relation with a moving image. + + b. Adapter's License means the license You apply to Your Copyright + and Similar Rights in Your contributions to Adapted Material in + accordance with the terms and conditions of this Public License. + + c. Copyright and Similar Rights means copyright and/or similar rights + closely related to copyright including, without limitation, + performance, broadcast, sound recording, and Sui Generis Database + Rights, without regard to how the rights are labeled or + categorized. For purposes of this Public License, the rights + specified in Section 2(b)(1)-(2) are not Copyright and Similar + Rights. + + d. Effective Technological Measures means those measures that, in the + absence of proper authority, may not be circumvented under laws + fulfilling obligations under Article 11 of the WIPO Copyright + Treaty adopted on December 20, 1996, and/or similar international + agreements. + + e. Exceptions and Limitations means fair use, fair dealing, and/or + any other exception or limitation to Copyright and Similar Rights + that applies to Your use of the Licensed Material. + + f. Licensed Material means the artistic or literary work, database, + or other material to which the Licensor applied this Public + License. + + g. Licensed Rights means the rights granted to You subject to the + terms and conditions of this Public License, which are limited to + all Copyright and Similar Rights that apply to Your use of the + Licensed Material and that the Licensor has authority to license. + + h. Licensor means the individual(s) or entity(ies) granting rights + under this Public License. + + i. Share means to provide material to the public by any means or + process that requires permission under the Licensed Rights, such + as reproduction, public display, public performance, distribution, + dissemination, communication, or importation, and to make material + available to the public including in ways that members of the + public may access the material from a place and at a time + individually chosen by them. + + j. Sui Generis Database Rights means rights other than copyright + resulting from Directive 96/9/EC of the European Parliament and of + the Council of 11 March 1996 on the legal protection of databases, + as amended and/or succeeded, as well as other essentially + equivalent rights anywhere in the world. + + k. You means the individual or entity exercising the Licensed Rights + under this Public License. Your has a corresponding meaning. + + +Section 2 -- Scope. + + a. License grant. + + 1. Subject to the terms and conditions of this Public License, + the Licensor hereby grants You a worldwide, royalty-free, + non-sublicensable, non-exclusive, irrevocable license to + exercise the Licensed Rights in the Licensed Material to: + + a. reproduce and Share the Licensed Material, in whole or + in part; and + + b. produce, reproduce, and Share Adapted Material. + + 2. Exceptions and Limitations. For the avoidance of doubt, where + Exceptions and Limitations apply to Your use, this Public + License does not apply, and You do not need to comply with + its terms and conditions. + + 3. Term. The term of this Public License is specified in Section + 6(a). + + 4. Media and formats; technical modifications allowed. The + Licensor authorizes You to exercise the Licensed Rights in + all media and formats whether now known or hereafter created, + and to make technical modifications necessary to do so. The + Licensor waives and/or agrees not to assert any right or + authority to forbid You from making technical modifications + necessary to exercise the Licensed Rights, including + technical modifications necessary to circumvent Effective + Technological Measures. For purposes of this Public License, + simply making modifications authorized by this Section 2(a) + (4) never produces Adapted Material. + + 5. Downstream recipients. + + a. Offer from the Licensor -- Licensed Material. Every + recipient of the Licensed Material automatically + receives an offer from the Licensor to exercise the + Licensed Rights under the terms and conditions of this + Public License. + + b. No downstream restrictions. You may not offer or impose + any additional or different terms or conditions on, or + apply any Effective Technological Measures to, the + Licensed Material if doing so restricts exercise of the + Licensed Rights by any recipient of the Licensed + Material. + + 6. No endorsement. Nothing in this Public License constitutes or + may be construed as permission to assert or imply that You + are, or that Your use of the Licensed Material is, connected + with, or sponsored, endorsed, or granted official status by, + the Licensor or others designated to receive attribution as + provided in Section 3(a)(1)(A)(i). + + b. Other rights. + + 1. Moral rights, such as the right of integrity, are not + licensed under this Public License, nor are publicity, + privacy, and/or other similar personality rights; however, to + the extent possible, the Licensor waives and/or agrees not to + assert any such rights held by the Licensor to the limited + extent necessary to allow You to exercise the Licensed + Rights, but not otherwise. + + 2. Patent and trademark rights are not licensed under this + Public License. + + 3. To the extent possible, the Licensor waives any right to + collect royalties from You for the exercise of the Licensed + Rights, whether directly or through a collecting society + under any voluntary or waivable statutory or compulsory + licensing scheme. In all other cases the Licensor expressly + reserves any right to collect such royalties. + + +Section 3 -- License Conditions. + +Your exercise of the Licensed Rights is expressly made subject to the +following conditions. + + a. Attribution. + + 1. If You Share the Licensed Material (including in modified + form), You must: + + a. retain the following if it is supplied by the Licensor + with the Licensed Material: + + i. identification of the creator(s) of the Licensed + Material and any others designated to receive + attribution, in any reasonable manner requested by + the Licensor (including by pseudonym if + designated); + + ii. a copyright notice; + + iii. a notice that refers to this Public License; + + iv. a notice that refers to the disclaimer of + warranties; + + v. a URI or hyperlink to the Licensed Material to the + extent reasonably practicable; + + b. indicate if You modified the Licensed Material and + retain an indication of any previous modifications; and + + c. indicate the Licensed Material is licensed under this + Public License, and include the text of, or the URI or + hyperlink to, this Public License. + + 2. You may satisfy the conditions in Section 3(a)(1) in any + reasonable manner based on the medium, means, and context in + which You Share the Licensed Material. For example, it may be + reasonable to satisfy the conditions by providing a URI or + hyperlink to a resource that includes the required + information. + + 3. If requested by the Licensor, You must remove any of the + information required by Section 3(a)(1)(A) to the extent + reasonably practicable. + + 4. If You Share Adapted Material You produce, the Adapter's + License You apply must not prevent recipients of the Adapted + Material from complying with this Public License. + + +Section 4 -- Sui Generis Database Rights. + +Where the Licensed Rights include Sui Generis Database Rights that +apply to Your use of the Licensed Material: + + a. for the avoidance of doubt, Section 2(a)(1) grants You the right + to extract, reuse, reproduce, and Share all or a substantial + portion of the contents of the database; + + b. if You include all or a substantial portion of the database + contents in a database in which You have Sui Generis Database + Rights, then the database in which You have Sui Generis Database + Rights (but not its individual contents) is Adapted Material; and + + c. You must comply with the conditions in Section 3(a) if You Share + all or a substantial portion of the contents of the database. + +For the avoidance of doubt, this Section 4 supplements and does not +replace Your obligations under this Public License where the Licensed +Rights include other Copyright and Similar Rights. + + +Section 5 -- Disclaimer of Warranties and Limitation of Liability. + + a. UNLESS OTHERWISE SEPARATELY UNDERTAKEN BY THE LICENSOR, TO THE + EXTENT POSSIBLE, THE LICENSOR OFFERS THE LICENSED MATERIAL AS-IS + AND AS-AVAILABLE, AND MAKES NO REPRESENTATIONS OR WARRANTIES OF + ANY KIND CONCERNING THE LICENSED MATERIAL, WHETHER EXPRESS, + IMPLIED, STATUTORY, OR OTHER. THIS INCLUDES, WITHOUT LIMITATION, + WARRANTIES OF TITLE, MERCHANTABILITY, FITNESS FOR A PARTICULAR + PURPOSE, NON-INFRINGEMENT, ABSENCE OF LATENT OR OTHER DEFECTS, + ACCURACY, OR THE PRESENCE OR ABSENCE OF ERRORS, WHETHER OR NOT + KNOWN OR DISCOVERABLE. WHERE DISCLAIMERS OF WARRANTIES ARE NOT + ALLOWED IN FULL OR IN PART, THIS DISCLAIMER MAY NOT APPLY TO YOU. + + b. TO THE EXTENT POSSIBLE, IN NO EVENT WILL THE LICENSOR BE LIABLE + TO YOU ON ANY LEGAL THEORY (INCLUDING, WITHOUT LIMITATION, + NEGLIGENCE) OR OTHERWISE FOR ANY DIRECT, SPECIAL, INDIRECT, + INCIDENTAL, CONSEQUENTIAL, PUNITIVE, EXEMPLARY, OR OTHER LOSSES, + COSTS, EXPENSES, OR DAMAGES ARISING OUT OF THIS PUBLIC LICENSE OR + USE OF THE LICENSED MATERIAL, EVEN IF THE LICENSOR HAS BEEN + ADVISED OF THE POSSIBILITY OF SUCH LOSSES, COSTS, EXPENSES, OR + DAMAGES. WHERE A LIMITATION OF LIABILITY IS NOT ALLOWED IN FULL OR + IN PART, THIS LIMITATION MAY NOT APPLY TO YOU. + + c. The disclaimer of warranties and limitation of liability provided + above shall be interpreted in a manner that, to the extent + possible, most closely approximates an absolute disclaimer and + waiver of all liability. + + +Section 6 -- Term and Termination. + + a. This Public License applies for the term of the Copyright and + Similar Rights licensed here. However, if You fail to comply with + this Public License, then Your rights under this Public License + terminate automatically. + + b. Where Your right to use the Licensed Material has terminated under + Section 6(a), it reinstates: + + 1. automatically as of the date the violation is cured, provided + it is cured within 30 days of Your discovery of the + violation; or + + 2. upon express reinstatement by the Licensor. + + For the avoidance of doubt, this Section 6(b) does not affect any + right the Licensor may have to seek remedies for Your violations + of this Public License. + + c. For the avoidance of doubt, the Licensor may also offer the + Licensed Material under separate terms or conditions or stop + distributing the Licensed Material at any time; however, doing so + will not terminate this Public License. + + d. Sections 1, 5, 6, 7, and 8 survive termination of this Public + License. + + +Section 7 -- Other Terms and Conditions. + + a. The Licensor shall not be bound by any additional or different + terms or conditions communicated by You unless expressly agreed. + + b. Any arrangements, understandings, or agreements regarding the + Licensed Material not stated herein are separate from and + independent of the terms and conditions of this Public License. + + +Section 8 -- Interpretation. + + a. For the avoidance of doubt, this Public License does not, and + shall not be interpreted to, reduce, limit, restrict, or impose + conditions on any use of the Licensed Material that could lawfully + be made without permission under this Public License. + + b. To the extent possible, if any provision of this Public License is + deemed unenforceable, it shall be automatically reformed to the + minimum extent necessary to make it enforceable. If the provision + cannot be reformed, it shall be severed from this Public License + without affecting the enforceability of the remaining terms and + conditions. + + c. No term or condition of this Public License will be waived and no + failure to comply consented to unless expressly agreed to by the + Licensor. + + d. Nothing in this Public License constitutes or may be interpreted + as a limitation upon, or waiver of, any privileges and immunities + that apply to the Licensor or You, including from the legal + processes of any jurisdiction or authority. + + +======================================================================= + +Creative Commons is not a party to its public +licenses. Notwithstanding, Creative Commons may elect to apply one of +its public licenses to material it publishes and in those instances +will be considered the “Licensor.” The text of the Creative Commons +public licenses is dedicated to the public domain under the CC0 Public +Domain Dedication. Except for the limited purpose of indicating that +material is shared under a Creative Commons public license or as +otherwise permitted by the Creative Commons policies published at +creativecommons.org/policies, Creative Commons does not authorize the +use of the trademark "Creative Commons" or any other trademark or logo +of Creative Commons without its prior written consent including, +without limitation, in connection with any unauthorized modifications +to any of its public licenses or any other arrangements, +understandings, or agreements concerning use of licensed material. For +the avoidance of doubt, this paragraph does not form part of the +public licenses. + +Creative Commons may be contacted at creativecommons.org. + From 4f6bdc314a13489c6ce963b7f40b7cf599d98f46 Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Fri, 7 Jan 2022 17:10:23 -0800 Subject: [PATCH 05/75] Delete example-spec.pdf --- example-spec.pdf | Bin 122011 -> 0 bytes 1 file changed, 0 insertions(+), 0 deletions(-) delete mode 100644 example-spec.pdf diff --git a/example-spec.pdf b/example-spec.pdf deleted file mode 100644 index 2fe1b421d7915c9e237e731b82c010fd9d6043a6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 122011 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 r;84alV}43Y!EmH`agsAS8+rL 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�|IW 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 Date: Fri, 7 Jan 2022 17:42:23 -0800 Subject: [PATCH 06/75] Add a bibliography and index Simple example bibliography and index. Signed-off-by: Stephano Cetola --- bibliography.adoc | 4 + chapter2.adoc | 4 +- example.bib | 473 ---------------------------------------------- header.adoc | 6 + index.adoc | 2 + intro.adoc | 6 +- 6 files changed, 17 insertions(+), 478 deletions(-) create mode 100644 bibliography.adoc create mode 100644 index.adoc diff --git a/bibliography.adoc b/bibliography.adoc new file mode 100644 index 00000000..4cc3eb7f --- /dev/null +++ b/bibliography.adoc @@ -0,0 +1,4 @@ +[bibliography] +== Bibliography + +bibliography::[] diff --git a/chapter2.adoc b/chapter2.adoc index f6f0995b..6a2ff388 100644 --- a/chapter2.adoc +++ b/chapter2.adoc @@ -40,8 +40,8 @@ Seriously, multiple. === Sub section -Diam donec adipiscing tristique risus. Nisl rhoncus mattis rhoncus urna. Egestas egestas fringilla phasellus faucibus scelerisque eleifend donec pretium vulputate. Porta non pulvinar neque laoreet suspendisse interdum consectetur libero id. Massa vitae tortor condimentum lacinia quis vel. Donec ac odio tempor orci. Mi sit amet mauris commodo quis imperdiet massa tincidunt. Quis enim lobortis scelerisque fermentum dui. Lacus viverra vitae congue eu. Sed faucibus turpis in eu mi bibendum neque. Sit amet porttitor eget dolor. Aliquet eget sit amet tellus cras adipiscing enim. Id cursus metus aliquam eleifend mi. Vestibulum lorem sed risus ultricies tristique nulla aliquet. +Diam donec adipiscing tristique risus indexterm:[risus]. Nisl rhoncus mattis rhoncus urna. Egestas egestas fringilla phasellus faucibus scelerisque eleifend donec pretium vulputate. Porta non pulvinar neque laoreet suspendisse interdum consectetur libero id. Massa vitae tortor condimentum lacinia quis vel. Donec ac odio tempor orci. Mi sit amet mauris commodo quis imperdiet massa tincidunt. Quis enim lobortis scelerisque fermentum dui. Lacus viverra vitae congue eu. Sed faucibus turpis in eu mi bibendum neque. Sit amet porttitor eget dolor. Aliquet eget sit amet tellus cras adipiscing enim. Id cursus metus aliquam eleifend mi. Vestibulum lorem sed risus ultricies tristique nulla aliquet. === Yet another subsection -Quam lacus suspendisse faucibus interdum posuere lorem ipsum. Nulla aliquet enim tortor at auctor urna nunc id cursus. Massa massa ultricies mi quis hendrerit dolor magna. Integer enim neque volutpat ac tincidunt. Dolor magna eget est lorem ipsum dolor. Urna neque viverra justo nec. Neque gravida in fermentum et. Fringilla ut morbi tincidunt augue interdum velit euismod. Dolor sit amet consectetur adipiscing elit. Eu facilisis sed odio morbi. In cursus turpis massa tincidunt dui. Orci phasellus egestas tellus rutrum tellus. Semper eget duis at tellus at urna condimentum. Orci porta non pulvinar neque laoreet suspendisse interdum consectetur. +Quam lacus suspendisse faucibus interdum posuere lorem ipsum. Nulla aliquet enim tortor at auctor urna nunc id cursus. Massa massa ultricies mi quis hendrerit dolor magna. Integer enim neque volutpat ac tincidunt. Dolor magna eget est lorem ipsum dolor. Urna neque viverra justo nec. Neque gravida in fermentum et. Fringilla ut morbi tincidunt augue interdum velit euismod. Dolor sit amet consectetur adipiscing elit. Eu facilisis sed odio morbi. In cursus turpis massa tincidunt dui. Orci indexterm:[orci] phasellus egestas tellus rutrum tellus. Semper eget duis at tellus at urna condimentum. Orci porta non pulvinar neque laoreet suspendisse interdum consectetur. diff --git a/example.bib b/example.bib index 3d7157fc..dd4ca0b9 100644 --- a/example.bib +++ b/example.bib @@ -1,11 +1,3 @@ -@Misc{ieee754-2008, - key = "{IEEE}", - title = "{ANSI/IEEE Std 754-2008}, {IEEE} standard for - floating-point arithmetic", - publisher = {"Institute of Electrical and Electronic Engineers"}, - year = 2008 -} - @inproceedings{riscI-isca1981, title = {{RISC I}: {A} Reduced Instruction Set {VLSI} Computer}, author = {David A. Patterson and Carlo H. S\'{e}quin}, @@ -22,20 +14,6 @@ @InProceedings{Katevenis:1983 year = 1983, month = {August}} -@article{Katevenis:1984, - author = {Katevenis, Manolis G.H. and Sherburne,Jr., Robert W. and Patterson, David A. and S{\'e}quin, Carlo H.}, - title = {The {RISC II} micro-architecture}, - journal = {Advances in VLSI and Computur Systems}, - issue_date = {Fall 1984}, - volume = {1}, - number = {2}, - month = October, - year = {1984}, - pages = {138--152}, - publisher = {Computer Science Press, Inc.}, - address = {New York, NY, USA}, -} - @inproceedings{Ungar:1984, author = {David Ungar and Ricki Blau and Peter Foley and Dain Samples and David Patterson}, @@ -60,454 +38,3 @@ @Article{spur-jsscc1989 number = 6, pages = {1688--1698}, month = {December}} - -@MastersThesis{waterman-ms, - author = {Andrew Waterman}, - title = {{Improving Energy Efficiency and Reducing Code Size with RISC-V Compressed}}, - school = {University of California, Berkeley}, - year = 2011, - Number = {UCB/EECS-2011-63}, -} - -@phdthesis{waterman-phd, - Author = {Waterman, Andrew}, - Title = {Design of the {RISC-V} Instruction Set Architecture}, - School = {University of California, Berkeley}, - Year = {2016}, - Number = {UCB/EECS-2016-1}, -} - -@TechReport{riscvtr, - author = {Andrew Waterman and Yunsup Lee and David A. Patterson and Krste Asanovi\'{c}}, - title = {The {RISC-V} Instruction Set Manual, {Volume I}: {Base} - User-Level {ISA}}, - institution = {EECS Department, University of California, Berkeley}, - year = 2011, - number = {UCB/EECS-2011-62}, - month = {May}} - - - -@Book{kane:mips:1991, - author = {G. Kane and J. Heinrich}, - title = {MIPS RISC Architecture}, - publisher = {Prentice Hall}, - month = {September}, - year = 1991, - note = {ISBN 0135904722}, - edition = {2nd} -} - -@book{patterson:undergrad:2008, - author = {D. A. Patterson and J. L. Hennessy}, - title = {Computer Organization and Design: The - Hardware/Software Interface}, - edition = {4th}, - publisher = {Morgan Kaufmann}, - month = {November}, - year = {2008}, - note = {ISBN 0123744938} -} - -@Book{sweetman:mips:2006, - author = {D. Sweetman}, - title = {See {MIPS} Run}, - edition = {2nd}, - publisher = {Morgan Kaufmann}, - year = {2006}, - month = {October}, - note = {ISBN 0120884216} -} - -@Misc{mips:arch:2010, - author = {MIPS Technologies Inc.}, - title = {{MIPS32} Architecture for Programmers}, - year = {2010}, - note = {\verb!https://www.imgtec.com/mips/architectures/mips32/!} -} - -@Misc{sgi:mipspro:1997, - author = {Silicon Graphics Inc.}, - title = {{MIPSpro} 64-{B}it Porting and Translation Guide}, - year = {1997}, - note = {\verb!http://techpubs.sgi.com/!} -} - -@Misc{openriscarch, - author = {OpenCores}, - title = {{OpenRISC} 1000 Architecture Manual, Architecture - Version 1.0}, - month = {December}, - year = 2012} - -@ARTICLE{tremblay-vis-ieeemicro1996, -author={Tremblay, M. and O'Connor, J.M. and Narayanan, V. and Liang He}, -journal={IEEE Micro}, -title={{VIS} speeds new media processing}, -year={1996}, -month=AUG, -volume={16}, -number={4}, -pages={10 -20}, -keywords={3D graphics environments;RISC-style instructions;UltraSparc;VIS;Visual Instruction Set;media processing;media-processing algorithms;computer graphics;instruction sets;reduced instruction set computing;}, -ISSN={0272-1732},} - -@ARTICLE{lee-max-ieeemicro1996, -author={Lee, R.B.}, -journal={IEEE Micro}, -title={Subword parallelism with {MAX-2}}, -year={1996}, -month=AUG, -volume={16}, -number={4}, -pages={51 -59}, -keywords={MAX-2;instruction extensions;media processing;parallel computation;subword parallelism;word-oriented general-purpose processor;instruction sets;multimedia computing;parallel processing;}, -ISSN={0272-1732},} - -@ARTICLE{peleg-mmx-ieeemicro1996, -author={Peleg, A. and Weiser, U.}, -journal={IEEE Micro}, -title={{MMX} technology extension to the {Intel} architecture}, -year={1996}, -month=AUG, -volume={16}, -number={4}, -pages={42 -50}, -keywords={Intel architecture;MMX;SIMD;communications;compatibility;multimedia;operating systems;microprocessor chips;parallel architectures;}, -ISSN={0272-1732},} - -@ARTICLE{raman-sse-ieeemicro2000, -author={Raman, S.K. and Pentkovski, V. and Keshava, J.}, -journal={IEEE Micro}, -title={Implementing streaming {SIMD} extensions on the {Pentium}-{III} processor }, -year={2000}, -month=JUL/AUG, -volume={20}, -number={4}, -pages={47 -57}, -keywords={Internet;Pentium III developers;demanding multimedia;die size constraints;streaming SIMD extensions;instruction sets;microprocessor chips;}, -ISSN={0272-1732},} - -@misc{lomont-avx-irm2011, -author={Chris Lomont}, -title = {Introduction to {Intel Advanced Vector Extensions}}, -howpublished = {Intel White Paper}, -year = {2011}, -} - -@ARTICLE{goodacre-armisa-computer2005, -author={Goodacre, J. and Sloss, A.N.}, -journal={Computer}, -title={Parallelism and the {ARM} instruction set architecture}, -year={2005}, -month=JULY, -volume={38}, -number={7}, -pages={ 42 - 50}, -keywords={ ARM RISC processor; ARM chip design; ARM instruction set architecture; digital signal processor-like operations; exception handling; multiprocessing; reduced-instruction-set computing; subword parallelism; thread-level parallelism; variable execution time; instruction sets; microprocessor chips; parallel architectures; parallel programming; reduced instruction set computing;}, -ISSN={0018-9162},} - -@ARTICLE{diefendorff-altivec-ieeemicro2000, -author={Diefendorff, K. and Dubey, P.K. and Hochsprung, R. and Scale, H.}, -journal={IEEE Micro}, -title={{AltiVec} extension to {PowerPC} accelerates media processing}, -year={2000}, -month=MAR/APR, -volume={20}, -number={2}, -pages={85 -95}, -keywords={2D image processing;3D graphics;AltiVec extension;Apple G4;Hewlett-Packard added MAX;MDMX;MIPS architecture;MMX;Motorola's MPC 7400;PA-RISC architecture;PowerPC;PowerPC's AltiVec;SSE;Silicon Graphics;Sun enhanced Sparc;alias KNI;handwriting recognition;media mining;media processing;multimedia technologies;narrow/broadband signal processing;personal computing;digital signal processing chips;handwriting recognition;multimedia systems;parallel architectures;}, -ISSN={0272-1732},} - -@misc{gwennap-mdmx-mpr1996, -author={Linley Gwennap}, -title={Digital, {MIPS} Add Multimedia Extensions}, -howpublished = {Microprocessor Report}, -year = {1996}, -} -@article{majc, - author = {Tremblay, Marc and Chan, Jeffrey and Chaudhry, Shailender and Conigliaro, Andrew W. and Tse, Shing Sheung}, - title = {The {MAJC} Architecture: {A} Synthesis of Parallelism and Scalability}, - journal = {IEEE Micro}, - issue_date = {November 2000}, - volume = {20}, - number = {6}, - month = November, - year = {2000}, - pages = {12--25}, - publisher = {IEEE Computer Society Press}, - address = {Los Alamitos, CA, USA}, -} - -@InProceedings{tx2, - author = {John M. Frankovich and H. Philip Peterson}, - title = {A functional description of the {Lincoln} {TX-2} computer}, - booktitle = {Western Joint Computer Conference}, - year = 1957, - address = {Los Angeles, CA}, - month = {February} -} - - -@TechReport{heil-tr1996, - author = {Timothy H. Heil and James E. Smith}, - title = {Selective Dual Path Execution}, - institution = {University of Wisconsin - Madison}, - year = 1996, - month = {November}} - -@inproceedings{Klauser-1998, - author = {Klauser, A. and Austin, T. and Grunwald, D. and Calder, B.}, - title = {Dynamic Hammock Predication for Non-Predicated Instruction Set Architectures}, - booktitle = {Proceedings of the 1998 International Conference on Parallel Architectures and Compilation Techniques}, - series = {PACT '98}, - year = {1998}, - address = {Washington, DC, USA}, -} - -@inproceedings{Kim-micro2005, - author = {Kim, Hyesoon and Mutlu, Onur and Stark, Jared and Patt, Yale N.}, - title = {Wish Branches: Combining Conditional Branching and Predication for Adaptive Predicated Execution}, - booktitle = {Proceedings of the 38th annual IEEE/ACM International Symposium on Microarchitecture}, - series = {MICRO 38}, - year = {2005}, - location = {Barcelona, Spain}, - pages = {43--54}, -} - -@INPROCEEDINGS{Gharachorloo90memoryconsistency, - author = {Kourosh Gharachorloo and Daniel Lenoski and James Laudon - and Phillip Gibbons and Anoop Gupta and John - Hennessy}, - title = {Memory Consistency and Event Ordering in Scalable - Shared-Memory Multiprocessors}, - booktitle = {In Proceedings of the 17th Annual International - Symposium on Computer Architecture}, - year = {1990}, - pages = {15--26} -} - - -@inproceedings{Rajwar:2001:SLE, - author = {Rajwar, Ravi and Goodman, James R.}, - title = {Speculative lock elision: enabling highly concurrent multithreaded execution}, - booktitle = {Proceedings of the 34th annual ACM/IEEE International Symposium on Microarchitecture}, - series = {MICRO 34}, - year = {2001}, - location = {Austin, Texas}, - pages = {294--305}, - publisher = {IEEE Computer Society}, -} - -@Misc{sparcieee1994, - title = {{IEEE} Standard for a 32-bit microprocessor}, - howpublished = {IEEE Std. 1754-1994}, - year = 1994} - - -@Book{parisckane1995, - author = {Gerry Kane}, - title = {PA-RISC 2.0 Architecture}, - publisher = {Prentice Hall}, - year = 1995, - month = {December}, - note = {ISBN 978-0131827349}} - -@article{ibmpower7, - title={{IBM} {POWER7} multicore server processor}, - author={Sinharoy, Balaram and Kalla, R. and Starke, W. J. and Le, - H. Q. and Cargnoni, R. and Van Norstrand, J. A. and - Ronchetti, B. J. and Stuecheli, J. and Leenstra, - J. and Guthrie, G. L. and Nguyen, D. Q. and Blaner, - B. and Marino, C. F. and Retter, E. and Williams, P.}, - journal={IBM Journal of Research and Development}, - volume={55}, - number={3}, - pages={1--1}, - year={2011}, - publisher={IBM} -} - -@article{virtio, - author = {Russell, Rusty}, - title = {Virtio: {Towards} a De-facto Standard for Virtual {I/O} Devices}, - journal = {SIGOPS Oper. Syst. Rev.}, - issue_date = {July 2008}, - volume = {42}, - number = {5}, - month = jul, - year = {2008}, - issn = {0163-5980}, - pages = {95--103}, - numpages = {9}, - publisher = {ACM}, - address = {New York, NY, USA}, -} - -@ARTICLE{goldbergvm, -author={Goldberg, Robert P.}, -journal={Computer}, -title={Survey of virtual machine research}, -year={1974}, -month={June}, -volume={7}, -number={6}, -pages={34-45} -} - -@Manual{alphapalcode, - title = {{PALcode} for {Alpha} microprocessors: System Design - Guide}, - organization = {Digital Equipment Corporation}, - address = {Maynard, Massachusetts}, - note = {EC-QFGLC-TE}, - month = {May}, - year = 1996} - -@article{transparent-superpages, - author = {Navarro, Juan and Iyer, Sitaram and Druschel, Peter and Cox, Alan}, - title = {Practical, Transparent Operating System Support for Superpages}, - journal = {SIGOPS Oper. Syst. Rev.}, - issue_date = {Winter 2002}, - volume = {36}, - number = {SI}, - month = dec, - year = {2002}, - issn = {0163-5980}, - pages = {89--104}, - numpages = {16}, - url = {https://doi.org/10.1145/844128.844138}, - doi = {10.1145/844128.844138}, - acmid = {844138}, - publisher = {ACM}, - address = {New York, NY, USA}, -} - -@Book{stretch, - editor = {Werner Buchholz}, - title = {Planning a computer system: {Project} {Stretch}}, - publisher = {McGraw-Hill Book Company}, - year = 1962} - -@Article{ibm360, - author = {G. M. Amdahl and G. A. Blaauw and F. P. Brooks, Jr.}, - title = {Architecture of the {IBM} {System/360}}, - journal = {IBM Journal of R. \& D.}, - year = 1964, - volume = 8, - number = 2 -} - -@inproceedings{cdc6600, - author = {Thornton, James E.}, - title = {Parallel Operation in the {Control Data 6600}}, - booktitle = {Proceedings of the October 27-29, 1964, Fall Joint Computer Conference, Part II: Very High Speed Computer Systems}, - series = {AFIPS '64 (Fall, part II)}, - year = {1965}, - location = {San Francisco, California}, - pages = {33--40} -} - -@InProceedings{jtseng:sbbci, - author = {J. Tseng and K. Asanovi\'c}, - title = {Energy-Efficient Register Access}, - booktitle = {Proc. of the 13th Symposium on Integrated Circuits and - Systems Design}, - address = {Manaus, Brazil}, - month = {September}, - year = 2000, - pages = "377--384" -} - -@TechReport{riscvtr2, - author = {Andrew Waterman and Yunsup Lee and David A. Patterson and Krste Asanovi\'{c}}, - title = {The {RISC-V} Instruction Set Manual, {Volume I}: {Base} - User-Level {ISA} Version 2.0}, - institution = {EECS Department, University of California, Berkeley}, - year = 2014, - number = {UCB/EECS-2014-54}, - month = {May}} - -@Article{ibm370varch, - author = {W. Buchholz}, - title = "{The IBM System/370 vector architecture}", - journal = {IBM Systems Journal}, - year = 1986, - volume = 25, - number = 1, - pages = {51--62} -} - -@PhdThesis{krstephd, - author = {Krste Asanovi\'c}, - title = {Vector Microprocessors}, - school = {University of California at Berkeley}, - year = 1998, - month = {May}, - note = {Available as techreport UCB/CSD-98-1014} -} - -@InProceedings{vp200, - author = "Kenichi Miura and Keiichiro Uchida", - title = "{FACOM Vector Processor System: VP-100/VP-200}", - editor = "Kawalik", - volume = "F7", - booktitle = "Proceedings of NATO Advanced Research Workshop on - High Speed Computing", - year = 1984, - publisher = "Springer-Verlag", - note = "Also in: IEEE Tutorial Supercomputers: Design and - Applications. Kai Hwang(editor), pp59-73" -} -@Manual{crayx1asm, - title = {Cray Assembly Language {(CAL)} for {Cray} {X1} Systems Reference Manual}, - organization = {Cray Inc.}, - edition = {1.1}, - month = {June}, - year = 2003} -} - -@misc{riscv-elf-psabi, - title = {{RISC-V ELF psABI Specification}}, - howpublished = {\url{https://github.com/riscv/riscv-elf-psabi-doc/}} -} - -@misc{riscv-asm-manual, - title = {{RISC-V Assembly Programmer's Manual}}, - howpublished = {\url{https://github.com/riscv/riscv-asm-manual}} -} - -@inproceedings{lithe-pan-hotpar09, -author = {Heidi Pan and Benjamin Hindman and Krste Asanovi\'c}, -title = {{Lithe}: Enabling Efficient Composition of Parallel Libraries}, -booktitle = {Proceedings of the 1st USENIX Workshop on Hot Topics in Parallelism (HotPar~'09)}, -month = {March}, -year = {2009}, -address = {Berkeley, CA}} - - -@inproceedings{lithe-pan-pldi10, -author = {Heidi Pan and Benjamin Hindman and Krste Asanovi\'c}, -title = {Composing Parallel Software Efficiently with {Lithe}}, -booktitle = {31st Conference on Programming Language Design and Implementation}, -month = {June}, -year = {2010}, -address = {Toronto, Canada}} - -@article{roux:hal-01091186, - TITLE = {{Innocuous Double Rounding of Basic Arithmetic Operations}}, - AUTHOR = {Roux, Pierre}, - URL = {https://hal.archives-ouvertes.fr/hal-01091186}, - JOURNAL = {{Journal of Formalized Reasoning}}, - PUBLISHER = {{ASDD-AlmaDL}}, - VOLUME = {7}, - NUMBER = {1}, - PAGES = {131-142}, - YEAR = {2014}, - MONTH = Nov, - DOI = {10.6092/issn.1972-5787/4359}, - KEYWORDS = {Coq ; double rounding ; floating-point arithmetic}, - PDF = {https://hal.archives-ouvertes.fr/hal-01091186/file/submission.pdf}, - HAL_ID = {hal-01091186}, - HAL_VERSION = {v1}, -} diff --git a/header.adoc b/header.adoc index acd2e78d..bcb34fdf 100644 --- a/header.adoc +++ b/header.adoc @@ -17,6 +17,9 @@ // needs to be changed? bug discussion started //:WaveDromEditorApp: app/wavedrom-editor.app :imagesoutdir: images +:bibtex-file: example.bib +:bibtex-order: alphabetical +:bibtex-style: apa :icons: font :lang: en :listing-caption: Listing @@ -38,3 +41,6 @@ Author 1; Author 2; RISC-V Task Group include::intro.adoc[] include::chapter2.adoc[] +//the index must precede the bibliography +include::index.adoc[] +include::bibliography.adoc[] diff --git a/index.adoc b/index.adoc new file mode 100644 index 00000000..4abaca24 --- /dev/null +++ b/index.adoc @@ -0,0 +1,2 @@ +[index] +== Index diff --git a/intro.adoc b/intro.adoc index 66b71aa1..0d623276 100644 --- a/intro.adoc +++ b/intro.adoc @@ -1,13 +1,13 @@ [[intro]] == Introduction -Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do *eiusmod tempor* incididunt ut labore et dolore magna aliqua. Felis imperdiet proin fermentum leo vel orci porta. Volutpat lacus laoreet non curabitur gravida. Posuere urna nec tincidunt praesent semper feugiat nibh. Elit ``ullamcorper`` dignissim cras tincidunt lobortis. Malesuada fames ac turpis egestas integer eget. Tristique sollicitudin nibh sit amet commodo. Sed felis eget velit aliquet. Sit amet aliquam id diam maecenas ultricies mi. Consectetur purus ut faucibus pulvinar. Lectus urna duis convallis convallis tellus id. Fermentum iaculis eu non diam. Feugiat in fermentum posuere urna nec tincidunt praesent semper feugiat. Urna nec tincidunt praesent semper feugiat nibh. +Lorem ipsum indexterm:[Lorem ipsum] dolor sit amet, consectetur adipiscing elit, sed do *eiusmod tempor* incididunt ut labore et dolore magna aliqua. Felis imperdiet proin fermentum leo vel orci porta. Volutpat lacus laoreet non curabitur indexterm:[curabitur] gravida indexterm:[gravida]. Posuere urna nec tincidunt praesent semper feugiat nibh. Elit ``ullamcorper`` dignissim cras tincidunt lobortis. Malesuada fames ac turpis egestas integer eget. Tristique sollicitudin nibh sit amet commodo. Sed felis eget velit aliquet. Sit amet aliquam id diam maecenas ultricies mi. Consectetur purus ut faucibus pulvinar. Lectus urna duis convallis convallis tellus id. Fermentum iaculis eu non diam. Feugiat in fermentum posuere urna nec tincidunt praesent semper feugiat. Urna nec tincidunt praesent semper feugiat nibh. -Commodo viverra maecenas accumsan lacus. Vulputate odio ut enim blandit volutpat maecenas volutpat blandit. Urna porttitor rhoncus dolor purus non. Tellus mauris a diam maecenas sed. Vitae auctor eu augue ut lectus. Ridiculus mus mauris vitae ultricies leo integer. Consequat semper viverra nam *libero* justo laoreet sit amet. Pellentesque pulvinar pellentesque habitant morbi tristique senectus et netus et. Ac placerat vestibulum lectus mauris ``ultrices`` eros in cursus turpis. Accumsan in nisl nisi scelerisque eu ultrices vitae. Cras ornare arcu dui vivamus. Vitae congue mauris rhoncus aenean. Consequat mauris nunc congue nisi vitae suscipit tellus. Tempus egestas sed sed risus pretium quam vulputate dignissim. Quis varius quam quisque id diam vel. Mattis nunc sed blandit libero volutpat sed cras ornare arcu. Amet mauris commodo quis imperdiet massa tincidunt nunc. +Commodo viverra maecenas accumsan lacus. Vulputate odio ut enim blandit indexterm:[blandit] volutpat maecenas volutpat blandit. Urna porttitor rhoncus dolor purus non. Tellus mauris a diam maecenas sed. Vitae auctor eu augue ut lectus. Ridiculus mus mauris vitae ultricies leo integer. Consequat semper viverra nam *libero* justo laoreet sit amet. Pellentesque pulvinar pellentesque habitant morbi tristique senectus et netus et. Ac placerat vestibulum lectus mauris ``ultrices`` eros in cursus turpis. Accumsan in nisl nisi scelerisque eu ultrices vitae. Cras ornare arcu dui vivamus. Vitae congue mauris rhoncus aenean. Consequat mauris nunc congue nisi vitae suscipit tellus. Tempus egestas sed sed risus pretium quam vulputate dignissim. Quis varius quam quisque id diam vel. Mattis nunc sed blandit libero volutpat sed cras ornare arcu. Amet mauris commodo quis imperdiet massa tincidunt nunc. [NOTE] ==== -Fames ac turpis egestas sed tempus urna et. Consequat nisl vel pretium lectus quam id leo in vitae. Velit scelerisque in dictum non. Eu volutpat odio facilisis mauris sit. +The name RISC-V indexterm:[RISC-V] was chosen to represent the fifth major RISC ISA design from UC Berkeley (RISC-I cite:[riscI-isca1981], RISC-II cite:[Katevenis:1983], SOAR cite:[Ungar:1984], and SPUR cite:[spur-jsscc1989] were the first four). We also pun on the use of the Roman numeral "V" to signify "variations" and "vectors", as support for a range of architecture research, including various data-parallel accelerators, is an explicit goal of the ISA design. ==== === Sub Section of Introduction From 97fa590324b59f89a135dda0af5d5710135723b2 Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Mon, 10 Jan 2022 08:26:44 -0800 Subject: [PATCH 07/75] Add gitignore Ignore all PDF output that is generated. Use GitHub actions and releases for publishing PDFs. Signed-off-by: Stephano Cetola --- .gitignore | 2 ++ 1 file changed, 2 insertions(+) create mode 100644 .gitignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..bd98a737 --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +*.pdf + From 6257bf76781a57c7ab3ad3ecc8264181733ffeb0 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Mon, 10 Jan 2022 13:07:19 -0500 Subject: [PATCH 08/75] Update docs-resources submodule Signed-off-by: Jeff Scheel --- docs-resources | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs-resources b/docs-resources index 84e9c0ac..8df2cea1 160000 --- a/docs-resources +++ b/docs-resources @@ -1 +1 @@ -Subproject commit 84e9c0ac213026c30effaadc81a4f7c962c49268 +Subproject commit 8df2cea11ac1c806d639b55157efa78bb1530da1 From 66c1e558523ec978ad4e81d8c985d05671eeff5c Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Mon, 10 Jan 2022 13:10:59 -0500 Subject: [PATCH 09/75] Use logo in docs-resources Signed-off-by: Jeff Scheel --- images/risc-v_logo.png | Bin 21600 -> 0 bytes 1 file changed, 0 insertions(+), 0 deletions(-) delete mode 100644 images/risc-v_logo.png diff --git a/images/risc-v_logo.png b/images/risc-v_logo.png deleted file mode 100644 index 19c41209ba50a9a0710f8801257015f19207ee27..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21600 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 From bac3cfdcfa9c8c96e343cbb28be9f1625f43813a Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Mon, 10 Jan 2022 11:12:32 -0800 Subject: [PATCH 10/75] Update resources and logo Push to the latest commit for docs-resources and pull in the new SVG logo Signed-off-by: Stephano Cetola --- docs-resources | 2 +- header.adoc | 2 +- images/riscv-logo.svg | 1 + 3 files changed, 3 insertions(+), 2 deletions(-) create mode 120000 images/riscv-logo.svg diff --git a/docs-resources b/docs-resources index 8df2cea1..f8eefefe 160000 --- a/docs-resources +++ b/docs-resources @@ -1 +1 @@ -Subproject commit 8df2cea11ac1c806d639b55157efa78bb1530da1 +Subproject commit f8eefefe22ac194ce50bd239f38a8940db30e45a diff --git a/header.adoc b/header.adoc index bcb34fdf..2b479c96 100644 --- a/header.adoc +++ b/header.adoc @@ -10,7 +10,7 @@ :colophon: :appendix-caption: Appendix :imagesdir: images -:title-logo-image: image:risc-v_logo.png[pdfwidth=3.25in,align=center] +:title-logo-image: image:riscv-logo.svg[pdfwidth=3.25in,align=center] // Settings: :experimental: :reproducible: diff --git a/images/riscv-logo.svg b/images/riscv-logo.svg new file mode 120000 index 00000000..e9665aec --- /dev/null +++ b/images/riscv-logo.svg @@ -0,0 +1 @@ +../docs-resources/images/riscv-logo.svg \ No newline at end of file From e7ebc219ad957bd6b8b8d018db7e48ae05ad733b Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Mon, 10 Jan 2022 14:24:54 -0800 Subject: [PATCH 11/75] keep the same naming scheme between logos Signed-off-by: Stephano Cetola --- docs-resources | 2 +- header.adoc | 2 +- images/risc-v_logo.svg | 1 + images/riscv-logo.svg | 1 - 4 files changed, 3 insertions(+), 3 deletions(-) create mode 120000 images/risc-v_logo.svg delete mode 120000 images/riscv-logo.svg diff --git a/docs-resources b/docs-resources index f8eefefe..6a2d5b1f 160000 --- a/docs-resources +++ b/docs-resources @@ -1 +1 @@ -Subproject commit f8eefefe22ac194ce50bd239f38a8940db30e45a +Subproject commit 6a2d5b1f929e0e25df0c832b522ed1fc0c78e325 diff --git a/header.adoc b/header.adoc index 2b479c96..ec614192 100644 --- a/header.adoc +++ b/header.adoc @@ -10,7 +10,7 @@ :colophon: :appendix-caption: Appendix :imagesdir: images -:title-logo-image: image:riscv-logo.svg[pdfwidth=3.25in,align=center] +:title-logo-image: image:risc-v_logo.svg[pdfwidth=3.25in,align=center] // Settings: :experimental: :reproducible: diff --git a/images/risc-v_logo.svg b/images/risc-v_logo.svg new file mode 120000 index 00000000..31e4a40b --- /dev/null +++ b/images/risc-v_logo.svg @@ -0,0 +1 @@ +../docs-resources/images/risc-v_logo.svg \ No newline at end of file diff --git a/images/riscv-logo.svg b/images/riscv-logo.svg deleted file mode 120000 index e9665aec..00000000 --- a/images/riscv-logo.svg +++ /dev/null @@ -1 +0,0 @@ -../docs-resources/images/riscv-logo.svg \ No newline at end of file From b98edf0054f7c4f92bc74a6caa30d40556e96fed Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Wed, 12 Jan 2022 06:52:51 -0800 Subject: [PATCH 12/75] Update build-pdf.yml $default-branch can be used in Workflow templates, but not in Workflows. --- .github/workflows/build-pdf.yml | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 9f0569da..1dfe2f76 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -5,9 +5,11 @@ name: Build Document PDF on: push: - branches: [ $default-branch ] + branches: + - main pull_request: - branches: [ $default-branch ] + branches: + - main workflow_dispatch: jobs: From f576fd1c9ebaddb1316de0296656ea59bd913c46 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Thu, 20 Jan 2022 16:13:24 -0500 Subject: [PATCH 13/75] Boilerplate README for projects Signed-off-by: Jeff Scheel --- readme.adoc | 51 ++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 50 insertions(+), 1 deletion(-) diff --git a/readme.adoc b/readme.adoc index ea89e845..f1ed80bc 100644 --- a/readme.adoc +++ b/readme.adoc @@ -1,3 +1,52 @@ = RISC-V docs-spec-template -A template for building RISC-V specifications. +This repository is used to prime GitHub repos for the RISC-V organization which will be used +to create specifications. + +**If you are reading this in a specification repo, please update the title for this section and +provide your introduction to your repository.** + += License + +This work is licensed under a Creative Commons Attribution 4.0 International License (CC-BY-4.0). +See the https://github.com/riscv/docs-spec-template/blob/main/LICENSE[LICENSE] file for details. + += Contributors + +Contributors to this specification are contained in the +https://github.com/riscv/docs-spec-template/blob/main/Contributors.adoc[Contributors.adoc] file. + += Dependencies + +This project is built using AsciiDoctor (Ruby). The repository has been setup to build the PDF on +checkin using GitHub actions. Workflow ependencies are located in the `dependencies` directory. + +For more information on the AsciiDoctor, specification guidelines, or building locally, see the +https://github.com/riscv/docs-dev-guide[RISC-V Documentation Developer Guide]. + += Cloning the project + +This project uses https://git-scm.com/book/en/v2/Git-Tools-Submodules[GitHub Submodules] +to include the https://github.com/riscv/docs-resources[RISC-V docs-resources project] +to achieve a common look and feel. + +When cloning this repository for the first time, you must either use +`git clone --recurse-submodules` or execute `git submodule init` and `git submodule update` after the clone to populate the docs-resources directory. Failure to clone the submodule, will result +in the PDF build fail with an error message like the following: + + $ make + asciidoctor-pdf \ + -a toc \ + -a compress \ + -a pdf-style=docs-resources/themes/riscv-pdf.yml \ + -a pdf-fontsdir=docs-resources/fonts \ + --failure-level=ERROR \ + -o profiles.pdf profiles.adoc + asciidoctor: ERROR: could not locate or load the built-in pdf theme `docs-resources/themes/riscv-pdf.yml'; reverting to default theme + No such file or directory - notoserif-regular-subset.ttf not found in docs-resources/fonts + Use --trace for backtrace + make: *** [Makefile:7: profiles.pdf] Error 1 + += Building the document + +The final specification form of PDF can be generated using the `make` command. From d0ba7c23bede21b000eb981ec8d271fea0a0e721 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Thu, 20 Jan 2022 16:14:26 -0500 Subject: [PATCH 14/75] Update ref to contributors document Signed-off-by: Jeff Scheel --- readme.adoc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.adoc b/readme.adoc index f1ed80bc..8b370cd9 100644 --- a/readme.adoc +++ b/readme.adoc @@ -14,7 +14,7 @@ See the https://github.com/riscv/docs-spec-template/blob/main/LICENSE[LICENSE] f = Contributors Contributors to this specification are contained in the -https://github.com/riscv/docs-spec-template/blob/main/Contributors.adoc[Contributors.adoc] file. +https://github.com/riscv/docs-spec-template/blob/main/contributors.adoc[contributors.adoc] file. = Dependencies From eb16693f5a5fd1f71cced6bfdb5202b311b4e8a8 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Thu, 20 Jan 2022 16:17:42 -0500 Subject: [PATCH 15/75] Create contributors.adoc Signed-of-by: Jeff Scheel --- contributors.adoc | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 contributors.adoc diff --git a/contributors.adoc b/contributors.adoc new file mode 100644 index 00000000..8c5358f7 --- /dev/null +++ b/contributors.adoc @@ -0,0 +1,6 @@ +== Contributors + +This RISC-V specification has been contributed to directly or indirectly by: + +[%hardbreaks] +* From bcbb2eb0abc0bcab9663a36b80bf530043fb2787 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Thu, 20 Jan 2022 16:33:09 -0500 Subject: [PATCH 16/75] Integrate contributors, add licensing & copyright Signed-off-by: Jeff Scheel --- contributors.adoc | 3 ++- header.adoc | 21 +++++++++++++++++++++ 2 files changed, 23 insertions(+), 1 deletion(-) diff --git a/contributors.adoc b/contributors.adoc index 8c5358f7..523d253e 100644 --- a/contributors.adoc +++ b/contributors.adoc @@ -3,4 +3,5 @@ This RISC-V specification has been contributed to directly or indirectly by: [%hardbreaks] -* +* Author1 +* Author2 diff --git a/header.adoc b/header.adoc index ec614192..359cf447 100644 --- a/header.adoc +++ b/header.adoc @@ -39,6 +39,27 @@ endif::[] = RISC-V Example Specification Document (Zexmpl) Author 1; Author 2; RISC-V Task Group +// Preable +[WARNING] +.This document is in the link:http://riscv.org/spec-state[Development state] +==== +Assume everything can change. This draft specification will change before +being accepted as standard, so implementations made to this draft +specification will likely not conform to the future standard. +==== + +[preface] +== Copyright and license information +This specification is licensed under the Creative Commons +Attribution 4.0 International License (CC-BY 4.0). The full +license text is available at +https://creativecommons.org/licenses/by/4.0/. + +Copyright 2022 by RISC-V International. + +[preface] +include::contributors.adoc[] + include::intro.adoc[] include::chapter2.adoc[] //the index must precede the bibliography From 190269345297d6c13a1482d990bd10a5766e70e5 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Fri, 21 Jan 2022 09:58:55 -0500 Subject: [PATCH 17/75] Minor edit Signed-off-by: Jeff Scheel --- readme.adoc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.adoc b/readme.adoc index 8b370cd9..ab050eb0 100644 --- a/readme.adoc +++ b/readme.adoc @@ -21,7 +21,7 @@ https://github.com/riscv/docs-spec-template/blob/main/contributors.adoc[contribu This project is built using AsciiDoctor (Ruby). The repository has been setup to build the PDF on checkin using GitHub actions. Workflow ependencies are located in the `dependencies` directory. -For more information on the AsciiDoctor, specification guidelines, or building locally, see the +For more information on AsciiDoctor, specification guidelines, or building locally, see the https://github.com/riscv/docs-dev-guide[RISC-V Documentation Developer Guide]. = Cloning the project From edacc13f9eb51dd5d4991cf12f004ca8541aa20a Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Thu, 27 Jan 2022 09:39:19 -0500 Subject: [PATCH 18/75] Correct typo Signed-off-by: Jeff Scheel --- header.adoc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/header.adoc b/header.adoc index 359cf447..56bffde7 100644 --- a/header.adoc +++ b/header.adoc @@ -39,7 +39,7 @@ endif::[] = RISC-V Example Specification Document (Zexmpl) Author 1; Author 2; RISC-V Task Group -// Preable +// Preamble [WARNING] .This document is in the link:http://riscv.org/spec-state[Development state] ==== From 5518bf54571d6dc1528e533a01f2f3101564eab6 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Wed, 16 Feb 2022 11:31:30 -0500 Subject: [PATCH 19/75] Use PDF var in clean. Signed-off-by: Jeff Scheel --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 1aad8f4e..e6f515df 100644 --- a/Makefile +++ b/Makefile @@ -18,4 +18,4 @@ build: $(HEADER_SOURCE) clean: - rm example-spec.pdf + rm $(PDF_RESULT) From 0ec234cbb0720541b14dff5ccf16de4ffce1d7f9 Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Thu, 3 Mar 2022 07:01:50 -0800 Subject: [PATCH 20/75] fix typo --- readme.adoc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/readme.adoc b/readme.adoc index ab050eb0..c4371509 100644 --- a/readme.adoc +++ b/readme.adoc @@ -19,7 +19,7 @@ https://github.com/riscv/docs-spec-template/blob/main/contributors.adoc[contribu = Dependencies This project is built using AsciiDoctor (Ruby). The repository has been setup to build the PDF on -checkin using GitHub actions. Workflow ependencies are located in the `dependencies` directory. +checkin using GitHub actions. Workflow dependencies are located in the `dependencies` directory. For more information on AsciiDoctor, specification guidelines, or building locally, see the https://github.com/riscv/docs-dev-guide[RISC-V Documentation Developer Guide]. From ef4bc14b6aebbf20e914a72444d4cb2740bb0368 Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Fri, 4 Mar 2022 14:20:57 -0800 Subject: [PATCH 21/75] Add prerelease option to manual run of build action This adds the option to do a prerelease of the pdf build when that worflow_dispatch is manually run. The name of the release is based of the branch or tag name, so ideally one would run this with a branch name of the style: v0.1.0. --- .github/workflows/build-pdf.yml | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 1dfe2f76..363e5481 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -11,6 +11,11 @@ on: branches: - main workflow_dispatch: + inputs: + prerelease: + description: 'Generate a pre-release.' + required: false + type: boolean jobs: build: @@ -59,3 +64,25 @@ jobs: name: example-spec.pdf path: example-spec.pdf retention-days: 7 + - name: Create Release + id: create_release + if: ${{ github.event.inputs.prerelease }} + uses: actions/create-release@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + tag_name: ${{ github.ref_name }} + release_name: Release ${{ github.ref_name }} + draft: false + prerelease: true + - name: Upload Release Asset + id: upload-release-asset + if: ${{ github.event.inputs.prerelease }} + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: ./example-spec.pdf + asset_name: example-spec.pdf + asset_content_type: application/pdf From 70761b25f8ba7ce9d8610bea3e715537627657b3 Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Mon, 18 Apr 2022 07:45:01 -0700 Subject: [PATCH 22/75] Add CONTRIBUTING file with license and DCO info As part of this template we require each specification to provide at minimum the license(s) that the repository requires and the statement regarding the DCO. Authors are encouraged to update this file with any additional comments relevant to their specification. Signed-off-by: Stephano Cetola --- CONTRIBUTING.md | 64 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100644 CONTRIBUTING.md diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 00000000..ab2007c6 --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,64 @@ +# Contribution Guidelines + +As an open-source project, we welcome and encourage the community to submit patches directly to the project. In our collaborative open source environment, standards and methods for submitting changes help reduce the chaos that can result from an active development community. + +This document explains how to submit patches to the project so your patch will be accepted quickly in the codebase. + +## Licensing + +Licensing is very important to open source projects. It helps ensure the software continues to be available under the terms that the author desired. + +This project uses the Creative Commons Attribution 4.0 International license, as found in the [LICENSE](https://github.com/riscv/docs-spec-template/blob/main/LICENSE) file in the project's repo. + +A license tells you what rights you have as an author, as provided by the copyright holder. It is important that the contributor fully understands the licensing rights and agrees to them. Sometimes the copyright holder isn't the contributor, such as when the contributor is doing work on behalf of a company. + +## Developer Certification of Origin (DCO) + +To make a good faith effort to ensure licensing criteria are met, this project requires the Developer Certificate of Origin (DCO) process to be followed. + +The DCO is an attestation attached to every contribution made by every author. In the commit message of the contribution (described more fully later in this document), the author simply adds a ``Signed-off-by`` statement and thereby agrees to the DCO. + +When an author submits a patch, it is a commitment that the contributor has the right to submit the patch per the license. The DCO agreement is shown below and at https://developercertificate.org. + +``` +Developer's Certificate of Origin 1.1 + +By making a contribution to this project, I certify that: + +(a) The contribution was created in whole or in part by me and I + have the right to submit it under the open source license + indicated in the file; or + +(b) The contribution is based upon previous work that, to the best + of my knowledge, is covered under an appropriate open source + license and I have the right under that license to submit that + work with modifications, whether created in whole or in part + by me, under the same open source license (unless I am + permitted to submit under a different license), as indicated + in the file; or + +(c) The contribution was provided directly to me by some other + person who certified (a), (b) or (c) and I have not modified + it. + +(d) I understand and agree that this project and the contribution + are public and that a record of the contribution (including all + personal information I submit with it, including my sign-off) is + maintained indefinitely and may be redistributed consistent with + this project or the open source license(s) involved. +``` + +### DCO Sign-Off Methods + +The DCO requires that a sign-off message, in the following format, appears on each commit in the pull request: + +`Signed-off-by: Stephano Cetola ` + +You are required to use your real name in the sign-off message. + +The DCO text can either be manually added to your commit body, or you can add either ``-s`` or ``--signoff`` to your usual Git commit commands. If you forget to add the sign-off you can also amend a previous commit with the sign-off by running ``git commit --amend -s``. If you've pushed your changes to GitHub already you'll need to force push your branch after this with ``git push -f``. + + +**Note:** + +The name and email address of the account you use to submit your PR must match the name and email address on the ``Signed-off-by`` line in your commit message. From 503123a50c3f6626830783cf7ba55d4829a3bb4c Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Mon, 18 Apr 2022 08:13:49 -0700 Subject: [PATCH 23/75] Update readme with contributing information Signed-off-by: Stephano Cetola --- readme.adoc | 3 +++ 1 file changed, 3 insertions(+) diff --git a/readme.adoc b/readme.adoc index c4371509..28a1cdb2 100644 --- a/readme.adoc +++ b/readme.adoc @@ -16,6 +16,9 @@ See the https://github.com/riscv/docs-spec-template/blob/main/LICENSE[LICENSE] f Contributors to this specification are contained in the https://github.com/riscv/docs-spec-template/blob/main/contributors.adoc[contributors.adoc] file. +For instructions on how to contribute please see the +https://github.com/riscv/docs-spec-template/blob/main/CONTRIBUTING.md[CONTRIBUTING] file. + = Dependencies This project is built using AsciiDoctor (Ruby). The repository has been setup to build the PDF on From 07d1b122583f066cc3dbf6a87dd836e92d3133e1 Mon Sep 17 00:00:00 2001 From: Stephano Cetola Date: Mon, 18 Apr 2022 08:15:25 -0700 Subject: [PATCH 24/75] Update contributors file with required email Signed-off-by: Stephano Cetola --- contributors.adoc | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/contributors.adoc b/contributors.adoc index 523d253e..13fd7768 100644 --- a/contributors.adoc +++ b/contributors.adoc @@ -3,5 +3,5 @@ This RISC-V specification has been contributed to directly or indirectly by: [%hardbreaks] -* Author1 -* Author2 +* Author1 +* Author2 From 8b7540971702247c3eb76ff2cdce32f2531d85b1 Mon Sep 17 00:00:00 2001 From: Bin Meng Date: Tue, 21 Jun 2022 19:37:58 +0800 Subject: [PATCH 25/75] Trim trailing whitespaces in adoc files Signed-off-by: Bin Meng --- chapter2.adoc | 4 ++-- header.adoc | 8 ++++---- readme.adoc | 14 +++++++------- 3 files changed, 13 insertions(+), 13 deletions(-) diff --git a/chapter2.adoc b/chapter2.adoc index 6a2ff388..8c118202 100644 --- a/chapter2.adoc +++ b/chapter2.adoc @@ -7,7 +7,7 @@ + .. The first sub item. -.. The second sub item. +.. The second sub item. + [CAUTION] ==== @@ -18,7 +18,7 @@ A moment of caution is required for this block of text must be read and apreciat . Again, an item. -.. A multi-line item. +.. A multi-line item. + This item has multiple lines. + diff --git a/header.adoc b/header.adoc index 56bffde7..3f06ee1b 100644 --- a/header.adoc +++ b/header.adoc @@ -43,15 +43,15 @@ Author 1; Author 2; RISC-V Task Group [WARNING] .This document is in the link:http://riscv.org/spec-state[Development state] ==== -Assume everything can change. This draft specification will change before -being accepted as standard, so implementations made to this draft +Assume everything can change. This draft specification will change before +being accepted as standard, so implementations made to this draft specification will likely not conform to the future standard. ==== [preface] == Copyright and license information -This specification is licensed under the Creative Commons -Attribution 4.0 International License (CC-BY 4.0). The full +This specification is licensed under the Creative Commons +Attribution 4.0 International License (CC-BY 4.0). The full license text is available at https://creativecommons.org/licenses/by/4.0/. diff --git a/readme.adoc b/readme.adoc index 28a1cdb2..d6c1b07a 100644 --- a/readme.adoc +++ b/readme.adoc @@ -1,19 +1,19 @@ = RISC-V docs-spec-template -This repository is used to prime GitHub repos for the RISC-V organization which will be used -to create specifications. +This repository is used to prime GitHub repos for the RISC-V organization which will be used +to create specifications. -**If you are reading this in a specification repo, please update the title for this section and +**If you are reading this in a specification repo, please update the title for this section and provide your introduction to your repository.** = License -This work is licensed under a Creative Commons Attribution 4.0 International License (CC-BY-4.0). +This work is licensed under a Creative Commons Attribution 4.0 International License (CC-BY-4.0). See the https://github.com/riscv/docs-spec-template/blob/main/LICENSE[LICENSE] file for details. = Contributors -Contributors to this specification are contained in the +Contributors to this specification are contained in the https://github.com/riscv/docs-spec-template/blob/main/contributors.adoc[contributors.adoc] file. For instructions on how to contribute please see the @@ -33,7 +33,7 @@ This project uses https://git-scm.com/book/en/v2/Git-Tools-Submodules[GitHub Sub to include the https://github.com/riscv/docs-resources[RISC-V docs-resources project] to achieve a common look and feel. -When cloning this repository for the first time, you must either use +When cloning this repository for the first time, you must either use `git clone --recurse-submodules` or execute `git submodule init` and `git submodule update` after the clone to populate the docs-resources directory. Failure to clone the submodule, will result in the PDF build fail with an error message like the following: @@ -48,7 +48,7 @@ in the PDF build fail with an error message like the following: asciidoctor: ERROR: could not locate or load the built-in pdf theme `docs-resources/themes/riscv-pdf.yml'; reverting to default theme No such file or directory - notoserif-regular-subset.ttf not found in docs-resources/fonts Use --trace for backtrace - make: *** [Makefile:7: profiles.pdf] Error 1 + make: *** [Makefile:7: profiles.pdf] Error 1 = Building the document From b4af449a16a6ffe0e47d6d2da1bf0aec42c98e11 Mon Sep 17 00:00:00 2001 From: Bin Meng Date: Tue, 21 Jun 2022 20:11:24 +0800 Subject: [PATCH 26/75] readme: Link to relative file LICENSE, contributors.adoc and CONTRIBUTING.md are all local to this repo, so let's link to their relative path in the readme.adoc file. While we are here, omit the .adoc suffix in the the contributors.adoc link display name. Signed-off-by: Bin Meng --- readme.adoc | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/readme.adoc b/readme.adoc index d6c1b07a..e90f06dd 100644 --- a/readme.adoc +++ b/readme.adoc @@ -9,15 +9,13 @@ provide your introduction to your repository.** = License This work is licensed under a Creative Commons Attribution 4.0 International License (CC-BY-4.0). -See the https://github.com/riscv/docs-spec-template/blob/main/LICENSE[LICENSE] file for details. +See the link:LICENSE[LICENSE] file for details. = Contributors -Contributors to this specification are contained in the -https://github.com/riscv/docs-spec-template/blob/main/contributors.adoc[contributors.adoc] file. +Contributors to this specification are contained in the link:contributors.adoc[contributors] file. -For instructions on how to contribute please see the -https://github.com/riscv/docs-spec-template/blob/main/CONTRIBUTING.md[CONTRIBUTING] file. +For instructions on how to contribute please see the link:CONTRIBUTING.md[CONTRIBUTING] file. = Dependencies From 1bd246ebbd9996535689b56679ff53e839a328ce Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Tue, 30 Aug 2022 16:44:51 -0400 Subject: [PATCH 27/75] Remove release build Will add in as a separate workflow. Signed-off-by: Jeff Scheel --- .github/workflows/build-pdf.yml | 28 ---------------------------- 1 file changed, 28 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 363e5481..54543e2a 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -10,12 +10,6 @@ on: pull_request: branches: - main - workflow_dispatch: - inputs: - prerelease: - description: 'Generate a pre-release.' - required: false - type: boolean jobs: build: @@ -64,25 +58,3 @@ jobs: name: example-spec.pdf path: example-spec.pdf retention-days: 7 - - name: Create Release - id: create_release - if: ${{ github.event.inputs.prerelease }} - uses: actions/create-release@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - tag_name: ${{ github.ref_name }} - release_name: Release ${{ github.ref_name }} - draft: false - prerelease: true - - name: Upload Release Asset - id: upload-release-asset - if: ${{ github.event.inputs.prerelease }} - uses: actions/upload-release-asset@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: ./example-spec.pdf - asset_name: example-spec.pdf - asset_content_type: application/pdf From a24f73f3be5d496711abc43ed3f4f729a4d6a10f Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Tue, 30 Aug 2022 16:50:10 -0400 Subject: [PATCH 28/75] Make build workflow re-usable - Establish env var for target NAME - Add outputs.name and outputs.pdf-name for consumption by other workflows Signed-off-by: Jeff Scheel --- .github/workflows/build-pdf.yml | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 54543e2a..a9c230d2 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -10,17 +10,35 @@ on: pull_request: branches: - main + workflow_call: + outputs: + name: + description: "The base name of the pdf file (without .pdf extensions)" + value: ${{ jobs.build.outputs.name }} + pdf-name: + description: "The name of the pdf file (with .pdf extensions)" + value: ${{ jobs.build.outputs.pdf-name }} jobs: build: runs-on: ubuntu-latest env: + NAME: example-spec APT_PACKAGES_FILE: ${{ github.workspace }}/dependencies/apt_packages.txt BUNDLE_GEMFILE: ${{ github.workspace }}/dependencies/Gemfile BUNDLE_BIN: ${{ github.workspace }}/bin NPM_PACKAGE_FOLDER: ${{ github.workspace }}/dependencies + outputs: + name: ${{ steps.step1.outputs.name }} + pdf-name: ${{ steps.step2.outputs.pdf-name }} steps: + - name: Set outputs.name + id: step1 + run: echo "::set-output name=name::$NAME" + - name: Set outputs.pdf-name + id: step2 + run: echo "::set-output name=pdf-name::$NAME.pdf" - name: Checkout repository uses: actions/checkout@v2 with: @@ -55,6 +73,6 @@ jobs: - name: Archive PDF result uses: actions/upload-artifact@v2 with: - name: example-spec.pdf - path: example-spec.pdf + name: ${{ env.NAME }}.pdf + path: ${{ env.NAME }}.pdf retention-days: 7 From eb8fc89ce0251fb6bd324c15f7e44b2e6cc8b31a Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Tue, 30 Aug 2022 16:55:36 -0400 Subject: [PATCH 29/75] Re-enable manual WF dispatch Signed-off-by: Jeff Scheel --- .github/workflows/build-pdf.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index a9c230d2..d4f7f316 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -10,6 +10,7 @@ on: pull_request: branches: - main + workflow_dispatch: workflow_call: outputs: name: From d51a9e41ec03a4ebbb1c0bb758d9d41256b4bd21 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Tue, 30 Aug 2022 17:01:28 -0400 Subject: [PATCH 30/75] Create create-release.yml Signed-off-by: Jeff Scheel --- .github/workflows/create-release.yml | 55 ++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 .github/workflows/create-release.yml diff --git a/.github/workflows/create-release.yml b/.github/workflows/create-release.yml new file mode 100644 index 00000000..7c8bbe35 --- /dev/null +++ b/.github/workflows/create-release.yml @@ -0,0 +1,55 @@ +# This work flow includes source and PDF in Release. It relies on the build-pdf workflow to create the PDF. +# +# NOTE: At this time it only runs manually. + +name: Create Vector Document Release + +on: + workflow_dispatch: + inputs: + version: + description: 'Release version, e.g. X.Y.Z:' + required: true + type: string + prerelease: + description: 'Tag as a pre-release?' + required: false + type: boolean + default: true + draft: + description: 'Create release as a draft?' + required: false + type: boolean + default: false + +jobs: + build: + uses: ./.github/workflows/build-pdf.yml + release: + runs-on: ubuntu-latest + needs: build + steps: + - name: Create Release + id: create_release + uses: actions/create-release@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + tag_name: v${{ github.event.inputs.version }} + release_name: Release ${{ github.event.inputs.version }} + draft: ${{ github.event.inputs.draft }} + prerelease: ${{ github.event.inputs.prerelease }} + - name: Download Artifacts + uses: actions/download-artifact@v2 + with: + name: ${{ needs.build.outputs.pdf-name }} + - name: Upload Release Asset + id: upload-release-asset + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: ${{ needs.build.outputs.pdf-name }} + asset_name: ${{ needs.build.outputs.name }}_${{ github.event.inputs.version }}.pdf + asset_content_type: application/pdf From a0e523e508cf5d71dc30462ad43ec8c8979c7b5b Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Tue, 30 Aug 2022 17:26:43 -0400 Subject: [PATCH 31/75] Remove Vector from name Signed-off-by: Jeff Scheel --- .github/workflows/create-release.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/create-release.yml b/.github/workflows/create-release.yml index 7c8bbe35..1ac0d279 100644 --- a/.github/workflows/create-release.yml +++ b/.github/workflows/create-release.yml @@ -2,7 +2,7 @@ # # NOTE: At this time it only runs manually. -name: Create Vector Document Release +name: Create Document Release on: workflow_dispatch: From e2564c43fb437dfad2fdacff0fe9306309be45b4 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Wed, 16 Nov 2022 13:10:13 -0500 Subject: [PATCH 32/75] Update versions to address Node changes https://github.blog/changelog/2022-09-22-github-actions-all-actions-will-begin-running-on-node16-instead-of-node12/ Signed-off-by: Jeff Scheel --- .github/workflows/build-pdf.yml | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index d4f7f316..7778dace 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -36,12 +36,12 @@ jobs: steps: - name: Set outputs.name id: step1 - run: echo "::set-output name=name::$NAME" + run: echo "name=$NAME" >> $GITHUB_OUTPUT - name: Set outputs.pdf-name id: step2 - run: echo "::set-output name=pdf-name::$NAME.pdf" + run: echo "pdf-name=$NAME.pdf" >> $GITHUB_OUTPUT - name: Checkout repository - uses: actions/checkout@v2 + uses: actions/checkout@v3 with: submodules: 'true' - name: Install Ubuntu packages @@ -55,16 +55,16 @@ jobs: ruby-version: "2.6" bundler-cache: true # Node.js for wavedrom - - uses: actions/cache@v2 + - uses: actions/cache@v3 with: path: ~/.npm key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} restore-keys: | ${{ runner.os }}-node- - name: Setup Node.js - uses: actions/setup-node@v2 + uses: actions/setup-node@v3 with: - node-version: '14' + node-version: '16' - name: Install Node.js dependencies run: npm install ${NPM_PACKAGE_FOLDER} - name: Generate PDF @@ -72,7 +72,7 @@ jobs: PATH=${PATH}:${BUNDLE_BIN}:$(npm bin) \ make - name: Archive PDF result - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v3 with: name: ${{ env.NAME }}.pdf path: ${{ env.NAME }}.pdf From 8a74c70876c31d7692a27c7e820f51ca53f46ec8 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Wed, 16 Nov 2022 13:22:06 -0500 Subject: [PATCH 33/75] Update to address Node 12 deprecation https://github.blog/changelog/2022-09-22-github-actions-all-actions-will-begin-running-on-node16-instead-of-node12/ Signed-off-by: Jeff Scheel --- .github/workflows/create-release.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/create-release.yml b/.github/workflows/create-release.yml index 1ac0d279..fa4ce1a7 100644 --- a/.github/workflows/create-release.yml +++ b/.github/workflows/create-release.yml @@ -31,7 +31,7 @@ jobs: steps: - name: Create Release id: create_release - uses: actions/create-release@v1 + uses: actions/create-release@v2 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: @@ -40,7 +40,7 @@ jobs: draft: ${{ github.event.inputs.draft }} prerelease: ${{ github.event.inputs.prerelease }} - name: Download Artifacts - uses: actions/download-artifact@v2 + uses: actions/download-artifact@v3 with: name: ${{ needs.build.outputs.pdf-name }} - name: Upload Release Asset From a160a4ee886384a8c237d3d728b75e8150378d04 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Wed, 16 Nov 2022 13:36:32 -0500 Subject: [PATCH 34/75] Revert create-release to v1 Signed-off-by: Jeff Scheel --- .github/workflows/create-release.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/create-release.yml b/.github/workflows/create-release.yml index fa4ce1a7..1f18485d 100644 --- a/.github/workflows/create-release.yml +++ b/.github/workflows/create-release.yml @@ -31,7 +31,7 @@ jobs: steps: - name: Create Release id: create_release - uses: actions/create-release@v2 + uses: actions/create-release@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: From fdcf3942c50f6112caa8c41ba677ada9084999de Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Wed, 23 Nov 2022 16:32:40 -0500 Subject: [PATCH 35/75] Explicitly set Ubuntu to 22.04 Signed-off-by: Jeff Scheel --- .github/workflows/build-pdf.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 7778dace..b53d15fe 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -22,7 +22,7 @@ on: jobs: build: - runs-on: ubuntu-latest + runs-on: ubuntu-22.04 env: NAME: example-spec From f8f740c73a52281b387538c72d37fc2668bc55f1 Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Wed, 23 Nov 2022 16:34:34 -0500 Subject: [PATCH 36/75] Explicitly restrict to 20.04 Note, this is because 22.04 fails. Signed-off-by: Jeff Scheel --- .github/workflows/build-pdf.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index b53d15fe..dfa75e4d 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -22,7 +22,7 @@ on: jobs: build: - runs-on: ubuntu-22.04 + runs-on: ubuntu-20.04 env: NAME: example-spec From fdf6097d9971b1b0f5d7e22deba6d97664fd5bfb Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Mon, 28 Nov 2022 09:06:59 -0500 Subject: [PATCH 37/75] Remove archived WF actions Replace actions/create-release and actions/upload-release-assets with softprops/action-gh-release Signed-off-by: Jeff Scheel --- .github/workflows/create-release.yml | 26 +++++++------------------- 1 file changed, 7 insertions(+), 19 deletions(-) diff --git a/.github/workflows/create-release.yml b/.github/workflows/create-release.yml index 1f18485d..014c0e50 100644 --- a/.github/workflows/create-release.yml +++ b/.github/workflows/create-release.yml @@ -29,27 +29,15 @@ jobs: runs-on: ubuntu-latest needs: build steps: - - name: Create Release - id: create_release - uses: actions/create-release@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - tag_name: v${{ github.event.inputs.version }} - release_name: Release ${{ github.event.inputs.version }} - draft: ${{ github.event.inputs.draft }} - prerelease: ${{ github.event.inputs.prerelease }} - name: Download Artifacts uses: actions/download-artifact@v3 with: name: ${{ needs.build.outputs.pdf-name }} - - name: Upload Release Asset - id: upload-release-asset - uses: actions/upload-release-asset@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Create Release + uses: softprops/action-gh-release@v1 with: - upload_url: ${{ steps.create_release.outputs.upload_url }} - asset_path: ${{ needs.build.outputs.pdf-name }} - asset_name: ${{ needs.build.outputs.name }}_${{ github.event.inputs.version }}.pdf - asset_content_type: application/pdf + files: ${{ needs.build.outputs.pdf-name }} + tag_name: v${{ github.event.inputs.version }} + name: Release ${{ github.event.inputs.version }} + draft: ${{ github.event.inputs.draft }} + prerelease: ${{ github.event.inputs.prerelease }} From 33f55b82b402d6268dd6fe652d1cdd73ae91edb8 Mon Sep 17 00:00:00 2001 From: Bill Traynor Date: Thu, 1 Dec 2022 12:25:53 -0500 Subject: [PATCH 38/75] Update build-pdf.yml Switched back to ubuntu-latest to see errors. Signed-off-by: Bill Traynor --- .github/workflows/build-pdf.yml | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index dfa75e4d..34c5641f 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -22,8 +22,9 @@ on: jobs: build: - runs-on: ubuntu-20.04 - + #runs-on: ubuntu-20.04 + runs-on: ubuntu-latest + env: NAME: example-spec APT_PACKAGES_FILE: ${{ github.workspace }}/dependencies/apt_packages.txt From bc76ecbf4ab4983f929b8e3dcefbad821983fe56 Mon Sep 17 00:00:00 2001 From: Bill Traynor Date: Thu, 1 Dec 2022 12:46:07 -0500 Subject: [PATCH 39/75] Update build-pdf.yml Try with ubuntu-22.04 Signed-off-by: Bill Traynor --- .github/workflows/build-pdf.yml | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 34c5641f..ae261c29 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -22,9 +22,8 @@ on: jobs: build: - #runs-on: ubuntu-20.04 - runs-on: ubuntu-latest - + runs-on: ubuntu-22.04 + env: NAME: example-spec APT_PACKAGES_FILE: ${{ github.workspace }}/dependencies/apt_packages.txt From 270788ad5cb08a653cf2788dae1637666ec7d716 Mon Sep 17 00:00:00 2001 From: Bill Traynor Date: Thu, 1 Dec 2022 13:19:10 -0500 Subject: [PATCH 40/75] Update build-pdf.yml Trying with Ruby 2.7 Signed-off-by: Bill Traynor --- .github/workflows/build-pdf.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index ae261c29..a88dd6c2 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -52,7 +52,7 @@ jobs: - name: Setup Ruby and Gemfile content uses: ruby/setup-ruby@v1 with: - ruby-version: "2.6" + ruby-version: "2.7" bundler-cache: true # Node.js for wavedrom - uses: actions/cache@v3 From 2db74877ab220f620f66167f2603b0cbc4e990e6 Mon Sep 17 00:00:00 2001 From: Bill Traynor Date: Thu, 1 Dec 2022 13:58:37 -0500 Subject: [PATCH 41/75] Update build-pdf.yml Switched back to ruby 2.6 Signed-off-by: Bill Traynor --- .github/workflows/build-pdf.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index a88dd6c2..ae261c29 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -52,7 +52,7 @@ jobs: - name: Setup Ruby and Gemfile content uses: ruby/setup-ruby@v1 with: - ruby-version: "2.7" + ruby-version: "2.6" bundler-cache: true # Node.js for wavedrom - uses: actions/cache@v3 From c00459ab3d77af1b56eb8bf176f586dea03690c1 Mon Sep 17 00:00:00 2001 From: Bill Traynor Date: Thu, 1 Dec 2022 14:11:27 -0500 Subject: [PATCH 42/75] Update apt_packages.txt added libwebp Signed-off-by: Bill Traynor --- dependencies/apt_packages.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/dependencies/apt_packages.txt b/dependencies/apt_packages.txt index 378b1351..5735979b 100644 --- a/dependencies/apt_packages.txt +++ b/dependencies/apt_packages.txt @@ -17,3 +17,4 @@ make pkg-config ruby ruby-dev +libwebp From 9a6edcbec350dc544e5d5b94d9a9692e73380703 Mon Sep 17 00:00:00 2001 From: Bill Traynor Date: Thu, 1 Dec 2022 14:13:09 -0500 Subject: [PATCH 43/75] Update apt_packages.txt added libwebp-dev Signed-off-by: Bill Traynor --- dependencies/apt_packages.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/dependencies/apt_packages.txt b/dependencies/apt_packages.txt index 5735979b..bdf2ce0b 100644 --- a/dependencies/apt_packages.txt +++ b/dependencies/apt_packages.txt @@ -17,4 +17,4 @@ make pkg-config ruby ruby-dev -libwebp +libwebp-dev From 7c72e995df2af5ea9591bdfe6044b8223fbd4f2f Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Thu, 1 Dec 2022 15:05:37 -0500 Subject: [PATCH 44/75] Add zstd-dev library to fix gem install asciidoctor-mathematic Fix for Issue #8 Signed-off-by: Jeff Scheel --- dependencies/apt_packages.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/dependencies/apt_packages.txt b/dependencies/apt_packages.txt index bdf2ce0b..0682bde7 100644 --- a/dependencies/apt_packages.txt +++ b/dependencies/apt_packages.txt @@ -18,3 +18,4 @@ pkg-config ruby ruby-dev libwebp-dev +libzstd-dev From a76f651eacba3f1b5ca65847a9403a3d95cd70b9 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Thu, 9 Feb 2023 11:34:06 -0300 Subject: [PATCH 45/75] Update readme.adoc Add the steps to build from a base container image Signed-off-by: Rafael Sene --- readme.adoc | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/readme.adoc b/readme.adoc index e90f06dd..15df15c9 100644 --- a/readme.adoc +++ b/readme.adoc @@ -51,3 +51,29 @@ in the PDF build fail with an error message like the following: = Building the document The final specification form of PDF can be generated using the `make` command. + += Build the document from a container + +To avoid dealing with configurations and dependencies, you can easily build this documentation from within a base container image which contains everything you need. Here are the steps: + +NOTE: https://docs.docker.com/engine/install/[ensure you have Docker installed] + +``` +$ git clone https://github.com/riscv/docs-dev-guide.git + +$ docker pull riscvintl/riscv-docs-base-container-image:latest + +$ docker run -it -v $(pwd)/docs-spec-template:/build riscvintl/riscv-docs-base-container-image:latest /bin/sh -c 'make' + +Building asciidoc +asciidoctor-pdf \ + --attribute=mathematical-format=svg \ + --attribute=pdf-fontsdir=docs-resources/fonts \ + --attribute=pdf-style=docs-resources/themes/riscv-pdf.yml \ + --failure-level=ERROR \ + --require=asciidoctor-bibtex \ + --require=asciidoctor-diagram \ + --require=asciidoctor-mathematical \ + --out-file=example-spec.pdf \ + header.adoc +``` From 0a5e626337b26c98c9194c8c3857405aa6bb43c1 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Tue, 11 Apr 2023 10:09:16 -0300 Subject: [PATCH 46/75] Updates to fix the build issues Signed-off-by: Rafael Sene --- CONTRIBUTING.md | 40 +++++++++++--------------- Makefile | 24 ++++++++-------- dependencies/apt_packages.txt | 12 +++++++- dependencies/package.json | 7 +++-- example.bib | 52 ++++++++++++++++------------------ header.adoc | 15 +++++----- images/risc-v_logo.png | Bin 0 -> 32482 bytes images/risc-v_logo.svg | 1 - 8 files changed, 76 insertions(+), 75 deletions(-) create mode 100755 images/risc-v_logo.png delete mode 120000 images/risc-v_logo.svg diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index ab2007c6..3c79557a 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,26 +1,23 @@ # Contribution Guidelines -As an open-source project, we welcome and encourage the community to submit patches directly to the project. In our collaborative open source environment, standards and methods for submitting changes help reduce the chaos that can result from an active development community. +As an open-source project, we appreciate and encourage community members to submit patches directly to the project. To maintain a well-organized development environment, we have established standards and methods for submitting changes. This document outlines the process for submitting patches to the project, ensuring that your contribution is swiftly incorporated into the codebase. -This document explains how to submit patches to the project so your patch will be accepted quickly in the codebase. +# Licensing -## Licensing +Licensing is crucial for open-source projects, as it guarantees that the software remains available under the conditions specified by the author. -Licensing is very important to open source projects. It helps ensure the software continues to be available under the terms that the author desired. +This project employs the Creative Commons Attribution 4.0 International license, which can be found in the LICENSE file within the project's repository. -This project uses the Creative Commons Attribution 4.0 International license, as found in the [LICENSE](https://github.com/riscv/docs-spec-template/blob/main/LICENSE) file in the project's repo. +Licensing defines the rights granted to you as an author by the copyright holder. It is essential for contributors to fully understand and accept these licensing rights. In some cases, the copyright holder may not be the contributor, such as when the contributor is working on behalf of a company. -A license tells you what rights you have as an author, as provided by the copyright holder. It is important that the contributor fully understands the licensing rights and agrees to them. Sometimes the copyright holder isn't the contributor, such as when the contributor is doing work on behalf of a company. +# Developer Certificate of Origin (DCO) +To uphold licensing criteria and demonstrate good faith, this project mandates adherence to the Developer Certificate of Origin (DCO) process. -## Developer Certification of Origin (DCO) +The DCO is an attestation appended to every contribution from each author. In the commit message of the contribution (explained in greater detail later in this document), the author adds a Signed-off-by statement, thereby accepting the DCO. -To make a good faith effort to ensure licensing criteria are met, this project requires the Developer Certificate of Origin (DCO) process to be followed. +When an author submits a patch, they affirm that they possess the right to submit the patch under the designated license. The DCO agreement is displayed below and at https://developercertificate.org. -The DCO is an attestation attached to every contribution made by every author. In the commit message of the contribution (described more fully later in this document), the author simply adds a ``Signed-off-by`` statement and thereby agrees to the DCO. -When an author submits a patch, it is a commitment that the contributor has the right to submit the patch per the license. The DCO agreement is shown below and at https://developercertificate.org. - -``` Developer's Certificate of Origin 1.1 By making a contribution to this project, I certify that: @@ -38,7 +35,7 @@ By making a contribution to this project, I certify that: in the file; or (c) The contribution was provided directly to me by some other - person who certified (a), (b) or (c) and I have not modified + person who certified (a), (b), or (c), and I have not modified it. (d) I understand and agree that this project and the contribution @@ -46,19 +43,16 @@ By making a contribution to this project, I certify that: personal information I submit with it, including my sign-off) is maintained indefinitely and may be redistributed consistent with this project or the open source license(s) involved. -``` - -### DCO Sign-Off Methods - -The DCO requires that a sign-off message, in the following format, appears on each commit in the pull request: -`Signed-off-by: Stephano Cetola ` +# DCO Sign-Off Methods +The DCO necessitates the inclusion of a sign-off message in the following format for each commit within the pull request: -You are required to use your real name in the sign-off message. +Signed-off-by: Stephano Cetola -The DCO text can either be manually added to your commit body, or you can add either ``-s`` or ``--signoff`` to your usual Git commit commands. If you forget to add the sign-off you can also amend a previous commit with the sign-off by running ``git commit --amend -s``. If you've pushed your changes to GitHub already you'll need to force push your branch after this with ``git push -f``. +Please use your real name in the sign-off message. +You can manually add the DCO text to your commit body or include either -s or --signoff in your standard Git commit commands. If you forget to incorporate the sign-off, you can also amend a previous commit with the sign-off by executing git commit --amend -s. If you have already pushed your changes to GitHub, you will need to force push your branch afterward using git push -f. -**Note:** +Note: -The name and email address of the account you use to submit your PR must match the name and email address on the ``Signed-off-by`` line in your commit message. +Ensure that the name and email address associated with your GitHub account match the name and email address in the Signed-off-by line of your commit message. \ No newline at end of file diff --git a/Makefile b/Makefile index e6f515df..eaff0cd0 100644 --- a/Makefile +++ b/Makefile @@ -1,21 +1,21 @@ HEADER_SOURCE := header.adoc PDF_RESULT := example-spec.pdf +ASCIIDOCTOR_PDF := asciidoctor-pdf +OPTIONS := --trace -a compress \ + --attribute=mathematical-format=svg \ + --attribute=pdf-fontsdir=docs-resources/fonts \ + --attribute=pdf-style=docs-resources/themes/riscv-pdf.yml \ + --failure-level=ERROR +REQUIRES := --require=asciidoctor-bibtex \ + --require=asciidoctor-diagram \ + --require=asciidoctor-mathematical + all: build build: - @echo "Building asciidoc" - asciidoctor-pdf \ - --attribute=mathematical-format=svg \ - --attribute=pdf-fontsdir=docs-resources/fonts \ - --attribute=pdf-style=docs-resources/themes/riscv-pdf.yml \ - --failure-level=ERROR \ - --require=asciidoctor-bibtex \ - --require=asciidoctor-diagram \ - --require=asciidoctor-mathematical \ - --out-file=$(PDF_RESULT) \ - $(HEADER_SOURCE) + $(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) --out-file=$(PDF_RESULT) $(HEADER_SOURCE) clean: - rm $(PDF_RESULT) + rm $(PDF_RESULT) \ No newline at end of file diff --git a/dependencies/apt_packages.txt b/dependencies/apt_packages.txt index 0682bde7..6ddd571c 100644 --- a/dependencies/apt_packages.txt +++ b/dependencies/apt_packages.txt @@ -1,21 +1,31 @@ bison build-essential +python3-pip cmake curl flex fonts-lyx git graphviz -# For wavedrom default-jre libcairo2-dev libffi-dev libgdk-pixbuf2.0-dev libpango1.0-dev libxml2-dev +libglib2.0-dev make pkg-config ruby ruby-dev +libgif-dev libwebp-dev libzstd-dev +ruby-full +gem +npm +texlive-latex-base +texlive-fonts-recommended +texlive-fonts-extra +texlive-latex-extra +texlive-science diff --git a/dependencies/package.json b/dependencies/package.json index 9d80afe6..7347d43a 100644 --- a/dependencies/package.json +++ b/dependencies/package.json @@ -1,7 +1,8 @@ { - "name": "local", - "version": "0.0.1", "dependencies": { + "bytefield-svg": "^1.8.0", "wavedrom-cli": "^2.6.8" - } + }, + "name": "local", + "version": "0.0.1" } diff --git a/example.bib b/example.bib index dd4ca0b9..9da24b15 100644 --- a/example.bib +++ b/example.bib @@ -2,39 +2,35 @@ @inproceedings{riscI-isca1981 title = {{RISC I}: {A} Reduced Instruction Set {VLSI} Computer}, author = {David A. Patterson and Carlo H. S\'{e}quin}, booktitle = {ISCA}, - location = {Minneapolis, Minnesota, USA}, + location = {Minneapolis, Minnesota, USA}, pages = {443-458}, year = {1981} } -@InProceedings{Katevenis:1983, - author = {Katevenis, Manolis G.H. and Sherburne,Jr., Robert W. and Patterson, David A. and S{\'e}quin, Carlo H.}, - title = {The {RISC II} micro-architecture}, +@inproceedings{Katevenis:1983, + author = {Manolis G.H. Katevenis and Robert W. Sherburne Jr. and David A. Patterson and Carlo H. S\'{e}quin}, + title = {The {RISC II} micro-architecture}, booktitle = {Proceedings VLSI 83 Conference}, - year = 1983, - month = {August}} + year = {1983}, + month = {August} +} @inproceedings{Ungar:1984, - author = {David Ungar and Ricki Blau and Peter Foley and Dain Samples - and David Patterson}, - title = {Architecture of {SOAR}: {Smalltalk} on a {RISC}}, - booktitle = {ISCA}, - address = {Ann Arbor, MI}, - year = {1984}, - pages = {188--197} -} + author = {David Ungar and Ricki Blau and Peter Foley and Dain Samples and David Patterson}, + title = {Architecture of {SOAR}: {Smalltalk} on a {RISC}}, + booktitle = {ISCA}, + address = {Ann Arbor, MI}, + year = {1984}, + pages = {188-197} +} -@Article{spur-jsscc1989, - author = {David D. Lee and Shing I. Kong and Mark D. Hill and - George S. Taylor and David A. Hodges and Randy - H. Katz and David A. Patterson}, - title = {A {VLSI} Chip Set for a Multiprocessor - Workstation--{Part I}: An {RISC} Microprocessor with - Coprocessor Interface and Support for Symbolic - Processing}, - journal = {IEEE JSSC}, - year = 1989, - volume = 24, - number = 6, - pages = {1688--1698}, - month = {December}} +@article{spur-jsscc1989, + author = {David D. Lee and Shing I. Kong and Mark D. Hill and George S. Taylor and David A. Hodges and Randy H. Katz and David A. Patterson}, + title = {A {VLSI} Chip Set for a Multiprocessor Workstation--{Part I}: An {RISC} Microprocessor with Coprocessor Interface and Support for Symbolic Processing}, + journal = {IEEE JSSC}, + year = {1989}, + volume = {24}, + number = {6}, + pages = {1688-1698}, + month = {December} +} \ No newline at end of file diff --git a/header.adoc b/header.adoc index 3f06ee1b..9c80801a 100644 --- a/header.adoc +++ b/header.adoc @@ -1,7 +1,10 @@ += RISC-V Example Specification Document (Zexmpl) +Author 1; Author 2; RISC-V Task Group + [[header]] :description: RISC-V Example Specification Document (Zexmpl) :company: RISC-V.org -:revdate: 1/2022 +:revdate: 1/2023 :revnumber: 1.0 :revremark: This document is in development. Assume everything can change. See http://riscv.org/spec-state for details. :url-riscv: http://riscv.org @@ -10,7 +13,7 @@ :colophon: :appendix-caption: Appendix :imagesdir: images -:title-logo-image: image:risc-v_logo.svg[pdfwidth=3.25in,align=center] +:title-logo-image: image:risc-v_logo.png[pdfwidth=3.25in,align=center] // Settings: :experimental: :reproducible: @@ -36,9 +39,6 @@ endif::[] :footnote: :xrefstyle: short -= RISC-V Example Specification Document (Zexmpl) -Author 1; Author 2; RISC-V Task Group - // Preamble [WARNING] .This document is in the link:http://riscv.org/spec-state[Development state] @@ -62,6 +62,7 @@ include::contributors.adoc[] include::intro.adoc[] include::chapter2.adoc[] -//the index must precede the bibliography + +// The index must precede the bibliography include::index.adoc[] -include::bibliography.adoc[] +include::bibliography.adoc[] \ No newline at end of file diff --git a/images/risc-v_logo.png b/images/risc-v_logo.png new file mode 100755 index 0000000000000000000000000000000000000000..4e826b2d2ff2e5ed8a5f8e6305618684aa79470e GIT binary patch literal 32482 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 Date: Tue, 11 Apr 2023 13:28:27 -0300 Subject: [PATCH 47/75] Update build-pdf.yml Signed-off-by: Rafael Sene --- .github/workflows/build-pdf.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index ae261c29..50e2de66 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -52,7 +52,7 @@ jobs: - name: Setup Ruby and Gemfile content uses: ruby/setup-ruby@v1 with: - ruby-version: "2.6" + ruby-version: "3.2.0" bundler-cache: true # Node.js for wavedrom - uses: actions/cache@v3 From d2564b3c1e7a1b26ac946b241895f1416c822069 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Mon, 17 Apr 2023 19:12:16 -0300 Subject: [PATCH 48/75] Update the build process to use containers and add some minor improvements Signed-off-by: Rafael Sene --- .github/workflows/build-pdf.yml | 83 ++++++-------------- .github/workflows/create-release.yml | 31 ++++---- Makefile | 28 +++++-- dependencies/README.md | 1 - readme.adoc | 109 ++++++++++++++++----------- 5 files changed, 123 insertions(+), 129 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 50e2de66..efc1e6c0 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -1,79 +1,42 @@ -# This workflow installs dependencies for PDF generation, generates the PDF, -# and uploads the PDF as an artifact. - -name: Build Document PDF +name: Build RISC-V Doc Spec Template on: + workflow_dispatch: push: branches: - main pull_request: branches: - main - workflow_dispatch: - workflow_call: - outputs: - name: - description: "The base name of the pdf file (without .pdf extensions)" - value: ${{ jobs.build.outputs.name }} - pdf-name: - description: "The name of the pdf file (with .pdf extensions)" - value: ${{ jobs.build.outputs.pdf-name }} jobs: build: - runs-on: ubuntu-22.04 - - env: - NAME: example-spec - APT_PACKAGES_FILE: ${{ github.workspace }}/dependencies/apt_packages.txt - BUNDLE_GEMFILE: ${{ github.workspace }}/dependencies/Gemfile - BUNDLE_BIN: ${{ github.workspace }}/bin - NPM_PACKAGE_FOLDER: ${{ github.workspace }}/dependencies - outputs: - name: ${{ steps.step1.outputs.name }} - pdf-name: ${{ steps.step2.outputs.pdf-name }} + runs-on: ubuntu-latest + steps: - - name: Set outputs.name - id: step1 - run: echo "name=$NAME" >> $GITHUB_OUTPUT - - name: Set outputs.pdf-name - id: step2 - run: echo "pdf-name=$NAME.pdf" >> $GITHUB_OUTPUT + # Checkout the repository - name: Checkout repository uses: actions/checkout@v3 - with: - submodules: 'true' - - name: Install Ubuntu packages + + # Pull the latest RISC-V Docs container image + # https://github.com/riscv/riscv-docs-base-container-image + # https://hub.docker.com/r/riscvintl/riscv-docs-base-container-image + - name: Pull Container run: | - sudo apt-get update - grep -vE '^#' ${APT_PACKAGES_FILE} | xargs sudo apt-get install --yes --no-install-recommends - # Ruby for asciidoctor - - name: Setup Ruby and Gemfile content - uses: ruby/setup-ruby@v1 - with: - ruby-version: "3.2.0" - bundler-cache: true - # Node.js for wavedrom - - uses: actions/cache@v3 - with: - path: ~/.npm - key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} - restore-keys: | - ${{ runner.os }}-node- - - name: Setup Node.js - uses: actions/setup-node@v3 - with: - node-version: '16' - - name: Install Node.js dependencies - run: npm install ${NPM_PACKAGE_FOLDER} - - name: Generate PDF + docker pull riscvintl/riscv-docs-base-container-image:latest + # Build PDF file using the container + - name: Build Files run: | - PATH=${PATH}:${BUNDLE_BIN}:$(npm bin) \ - make - - name: Archive PDF result + docker run --rm -v ${{ github.workspace }}:/build riscvintl/riscv-docs-base-container-image:latest \ + /bin/sh -c 'make' + # Set the short SHA for use in artifact names + - name: Set short SHA + run: echo "SHORT_SHA=$(echo ${GITHUB_SHA::7})" >> $GITHUB_ENV + + # Upload the built PDF file as artifact + - name: Upload Build Artifact uses: actions/upload-artifact@v3 with: - name: ${{ env.NAME }}.pdf - path: ${{ env.NAME }}.pdf + name: spec-sample-${{ env.SHORT_SHA }}.pdf + path: ${{ github.workspace }}/spec-sample.pdf retention-days: 7 diff --git a/.github/workflows/create-release.yml b/.github/workflows/create-release.yml index 014c0e50..90776dff 100644 --- a/.github/workflows/create-release.yml +++ b/.github/workflows/create-release.yml @@ -1,8 +1,4 @@ -# This work flow includes source and PDF in Release. It relies on the build-pdf workflow to create the PDF. -# -# NOTE: At this time it only runs manually. - -name: Create Document Release +name: Create Release on: workflow_dispatch: @@ -29,15 +25,16 @@ jobs: runs-on: ubuntu-latest needs: build steps: - - name: Download Artifacts - uses: actions/download-artifact@v3 - with: - name: ${{ needs.build.outputs.pdf-name }} - - name: Create Release - uses: softprops/action-gh-release@v1 - with: - files: ${{ needs.build.outputs.pdf-name }} - tag_name: v${{ github.event.inputs.version }} - name: Release ${{ github.event.inputs.version }} - draft: ${{ github.event.inputs.draft }} - prerelease: ${{ github.event.inputs.prerelease }} + - name: Download Artifacts + uses: actions/download-artifact@v3 + with: + name: ${{ needs.build.outputs.pdf-name }} + - name: Create Release + uses: softprops/action-gh-release@v1 + with: + files: ${{ needs.build.outputs.pdf-name }} + tag_name: v${{ github.event.inputs.version }} + name: Release ${{ github.event.inputs.version }} + draft: ${{ github.event.inputs.draft }} + prerelease: ${{ github.event.inputs.prerelease }} + body: "This release includes the document in PDF format." \ No newline at end of file diff --git a/Makefile b/Makefile index eaff0cd0..8de65a51 100644 --- a/Makefile +++ b/Makefile @@ -1,16 +1,32 @@ +# Makefile for RISC-V Doc Template +# +# This work is licensed under the Creative Commons Attribution-ShareAlike 4.0 +# International License. To view a copy of this license, visit +# http://creativecommons.org/licenses/by-sa/4.0/ or send a letter to +# Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. +# +# SPDX-License-Identifier: CC-BY-SA-4.0 +# +# Description: +# +# This Makefile is designed to automate the process of building and packaging +# the Doc Template for RISC-V Extensions. + HEADER_SOURCE := header.adoc -PDF_RESULT := example-spec.pdf +PDF_RESULT := spec-sample.pdf ASCIIDOCTOR_PDF := asciidoctor-pdf OPTIONS := --trace -a compress \ - --attribute=mathematical-format=svg \ - --attribute=pdf-fontsdir=docs-resources/fonts \ - --attribute=pdf-style=docs-resources/themes/riscv-pdf.yml \ + -a mathematical-format=svg \ + -a pdf-fontsdir=docs-resources/fonts \ + -a pdf-style=docs-resources/themes/riscv-pdf.yml \ --failure-level=ERROR REQUIRES := --require=asciidoctor-bibtex \ --require=asciidoctor-diagram \ --require=asciidoctor-mathematical +.PHONY: all build clean + all: build build: @@ -18,4 +34,6 @@ build: $(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) --out-file=$(PDF_RESULT) $(HEADER_SOURCE) clean: - rm $(PDF_RESULT) \ No newline at end of file + @echo "Cleaning up generated files" + rm -f $(PDF_RESULT) + diff --git a/dependencies/README.md b/dependencies/README.md index 0841ce89..f64a366a 100644 --- a/dependencies/README.md +++ b/dependencies/README.md @@ -1,3 +1,2 @@ Dependencies for the build environment for various package managers. Used in `.github/workflows/`. - diff --git a/readme.adoc b/readme.adoc index 15df15c9..d66fb5b4 100644 --- a/readme.adoc +++ b/readme.adoc @@ -1,70 +1,43 @@ = RISC-V docs-spec-template -This repository is used to prime GitHub repos for the RISC-V organization which will be used -to create specifications. +This repository serves as a template for creating GitHub repositories within the RISC-V organization that are intended for developing specifications. -**If you are reading this in a specification repo, please update the title for this section and -provide your introduction to your repository.** +**If you are reading this in a specification repository, please update the title for this section and provide a relevant introduction to your repository.** -= License +== License This work is licensed under a Creative Commons Attribution 4.0 International License (CC-BY-4.0). See the link:LICENSE[LICENSE] file for details. -= Contributors +== Contributors Contributors to this specification are contained in the link:contributors.adoc[contributors] file. For instructions on how to contribute please see the link:CONTRIBUTING.md[CONTRIBUTING] file. -= Dependencies +== Building the Document -This project is built using AsciiDoctor (Ruby). The repository has been setup to build the PDF on -checkin using GitHub actions. Workflow dependencies are located in the `dependencies` directory. - -For more information on AsciiDoctor, specification guidelines, or building locally, see the -https://github.com/riscv/docs-dev-guide[RISC-V Documentation Developer Guide]. - -= Cloning the project - -This project uses https://git-scm.com/book/en/v2/Git-Tools-Submodules[GitHub Submodules] -to include the https://github.com/riscv/docs-resources[RISC-V docs-resources project] -to achieve a common look and feel. +=== Building on Container -When cloning this repository for the first time, you must either use -`git clone --recurse-submodules` or execute `git submodule init` and `git submodule update` after the clone to populate the docs-resources directory. Failure to clone the submodule, will result -in the PDF build fail with an error message like the following: +To simplify the building process and avoid dealing with configurations and dependencies, you can build this documentation using a base container image, which contains everything you need. Follow these steps: - $ make - asciidoctor-pdf \ - -a toc \ - -a compress \ - -a pdf-style=docs-resources/themes/riscv-pdf.yml \ - -a pdf-fontsdir=docs-resources/fonts \ - --failure-level=ERROR \ - -o profiles.pdf profiles.adoc - asciidoctor: ERROR: could not locate or load the built-in pdf theme `docs-resources/themes/riscv-pdf.yml'; reverting to default theme - No such file or directory - notoserif-regular-subset.ttf not found in docs-resources/fonts - Use --trace for backtrace - make: *** [Makefile:7: profiles.pdf] Error 1 - -= Building the document - -The final specification form of PDF can be generated using the `make` command. - -= Build the document from a container - -To avoid dealing with configurations and dependencies, you can easily build this documentation from within a base container image which contains everything you need. Here are the steps: - -NOTE: https://docs.docker.com/engine/install/[ensure you have Docker installed] +Prerequisite: https://docs.docker.com/engine/install/[ensure you have Docker installed] +1 - Clone the repository ``` $ git clone https://github.com/riscv/docs-dev-guide.git - +$ cd ./docs-dev-guide +``` +2 - Pull the RISC-V documentation base container image: +``` $ docker pull riscvintl/riscv-docs-base-container-image:latest - +``` +3 - Run the container and execute the build: +``` $ docker run -it -v $(pwd)/docs-spec-template:/build riscvintl/riscv-docs-base-container-image:latest /bin/sh -c 'make' - +``` +Output: +``` Building asciidoc asciidoctor-pdf \ --attribute=mathematical-format=svg \ @@ -77,3 +50,47 @@ asciidoctor-pdf \ --out-file=example-spec.pdf \ header.adoc ``` +4 - Clean +``` +docker run -it -v $(pwd):/build riscvintl/riscv-docs-base-container-image:latest /bin/sh -c 'make clean' +``` +=== Buidling on Local Machine + +==== Dependencies + +This project is built using AsciiDoctor (Ruby). The repository has been setup to build the PDF on +checkin using GitHub actions. Workflow dependencies are located in the `dependencies` directory. + +For more information on AsciiDoctor, specification guidelines, or building locally, see the +https://github.com/riscv/docs-dev-guide[RISC-V Documentation Developer Guide]. + +==== Cloning the project + +This project uses https://git-scm.com/book/en/v2/Git-Tools-Submodules[GitHub Submodules] +to include the https://github.com/riscv/docs-resources[RISC-V docs-resources project] +to achieve a common look and feel. + +When cloning this repository for the first time, you must either use +`git clone --recurse-submodules` or execute `git submodule init` and `git submodule update` after the clone to populate the docs-resources directory. Failure to clone the submodule, will result +in the PDF build fail with an error message like the following: + +``` +$ make +asciidoctor-pdf \ +-a toc \ +-a compress \ +-a pdf-style=docs-resources/themes/riscv-pdf.yml \ +-a pdf-fontsdir=docs-resources/fonts \ +--failure-level=ERROR \ +-o profiles.pdf profiles.adoc + +asciidoctor: ERROR: could not locate or load the built-in pdf theme `docs-resources/themes/riscv-pdf.yml'; reverting to default theme +No such file or directory - notoserif-regular-subset.ttf not found in docs-resources/fonts + Use --trace for backtrace + +make: *** [Makefile:7: profiles.pdf] Error 1 +``` + +==== Building the document + +The final specification form of PDF can be generated using the `make` command. From f841ad0309c6e20f024a2fa38539a4b103087170 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Wed, 26 Apr 2023 09:15:39 -0300 Subject: [PATCH 49/75] Update build-pdf.yml This change adds a variable that collects the repository name and append it as part of the PDF generated by the build process. Signed-off-by: Rafael Sene --- .github/workflows/build-pdf.yml | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index efc1e6c0..8f34559c 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -1,4 +1,4 @@ -name: Build RISC-V Doc Spec Template +name: Build Specification on: workflow_dispatch: @@ -29,14 +29,16 @@ jobs: run: | docker run --rm -v ${{ github.workspace }}:/build riscvintl/riscv-docs-base-container-image:latest \ /bin/sh -c 'make' - # Set the short SHA for use in artifact names - - name: Set short SHA - run: echo "SHORT_SHA=$(echo ${GITHUB_SHA::7})" >> $GITHUB_ENV + # Set the short SHA and repo name for use in artifact names + - name: Set short SHA and repo name + run: | + echo "SHORT_SHA=$(echo ${GITHUB_SHA::7})" >> $GITHUB_ENV + echo "REPO_NAME=$(echo ${GITHUB_REPOSITORY##*/})" >> $GITHUB_ENV # Upload the built PDF file as artifact - name: Upload Build Artifact uses: actions/upload-artifact@v3 with: - name: spec-sample-${{ env.SHORT_SHA }}.pdf - path: ${{ github.workspace }}/spec-sample.pdf + name: ${{ env.REPO_NAME }}-${{ env.SHORT_SHA }}.pdf + path: ${{ github.workspace }}/*.pdf retention-days: 7 From da2d9685a35f6f5409facebf14d8646ea5e9b646 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Thu, 27 Apr 2023 16:28:32 -0300 Subject: [PATCH 50/75] Update the build workflow --- .github/workflows/build-pdf.yml | 45 ++++++++++++++++++++++------ .github/workflows/create-release.yml | 40 ------------------------- 2 files changed, 36 insertions(+), 49 deletions(-) delete mode 100644 .github/workflows/create-release.yml diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 8f34559c..7cbbb36f 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -1,13 +1,21 @@ -name: Build Specification +name: Build Document PDF on: workflow_dispatch: - push: - branches: - - main - pull_request: - branches: - - main + inputs: + release_type: + description: 'Release type (draft or regular)' + required: true + type: string + default: 'regular' + version: + description: 'Release version, e.g. X.Y.Z:' + required: true + type: string + target_branch: + description: 'Target branch to run the workflow on' + required: true + default: 'main' jobs: build: @@ -24,11 +32,14 @@ jobs: - name: Pull Container run: | docker pull riscvintl/riscv-docs-base-container-image:latest + # Build PDF file using the container - name: Build Files + id: build_files run: | docker run --rm -v ${{ github.workspace }}:/build riscvintl/riscv-docs-base-container-image:latest \ /bin/sh -c 'make' + # Set the short SHA and repo name for use in artifact names - name: Set short SHA and repo name run: | @@ -39,6 +50,22 @@ jobs: - name: Upload Build Artifact uses: actions/upload-artifact@v3 with: - name: ${{ env.REPO_NAME }}-${{ env.SHORT_SHA }}.pdf - path: ${{ github.workspace }}/*.pdf + name: ${{ env.REPO_NAME }}-${{ env.SHORT_SHA }} + path: | + ${{ github.workspace }}/*.pdf retention-days: 7 + + - name: Create Release + if: steps.build_files.outcome == 'success' && github.event_name == 'workflow_dispatch' && github.event.inputs.release_type != '' + uses: softprops/action-gh-release@v1 + with: + draft: ${{ github.event.inputs.release_type == 'draft' }} + tag_name: v${{ github.event.inputs.version }} + name: ${{ env.CURRENT_DATE }} + body: | + This release was created by: ${{ github.event.sender.login }} + Release Notes: ${{ github.event.inputs.release_notes }} + files: | + ${{ github.workspace }}/*.pdf + env: + GITHUB_TOKEN: ${{ secrets.GHTOKEN }} diff --git a/.github/workflows/create-release.yml b/.github/workflows/create-release.yml deleted file mode 100644 index 90776dff..00000000 --- a/.github/workflows/create-release.yml +++ /dev/null @@ -1,40 +0,0 @@ -name: Create Release - -on: - workflow_dispatch: - inputs: - version: - description: 'Release version, e.g. X.Y.Z:' - required: true - type: string - prerelease: - description: 'Tag as a pre-release?' - required: false - type: boolean - default: true - draft: - description: 'Create release as a draft?' - required: false - type: boolean - default: false - -jobs: - build: - uses: ./.github/workflows/build-pdf.yml - release: - runs-on: ubuntu-latest - needs: build - steps: - - name: Download Artifacts - uses: actions/download-artifact@v3 - with: - name: ${{ needs.build.outputs.pdf-name }} - - name: Create Release - uses: softprops/action-gh-release@v1 - with: - files: ${{ needs.build.outputs.pdf-name }} - tag_name: v${{ github.event.inputs.version }} - name: Release ${{ github.event.inputs.version }} - draft: ${{ github.event.inputs.draft }} - prerelease: ${{ github.event.inputs.prerelease }} - body: "This release includes the document in PDF format." \ No newline at end of file From d3522c225a0e03fb82f9cf02f524937c7dd069a4 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Thu, 27 Apr 2023 17:59:40 -0300 Subject: [PATCH 51/75] Update build-pdf.yml Signed-off-by: Rafael Sene --- .github/workflows/build-pdf.yml | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 7cbbb36f..e8a8be56 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -16,6 +16,12 @@ on: description: 'Target branch to run the workflow on' required: true default: 'main' + pull_request: + branches: + - '*' + push: + branches: + - '*' jobs: build: @@ -50,7 +56,6 @@ jobs: - name: Upload Build Artifact uses: actions/upload-artifact@v3 with: - name: ${{ env.REPO_NAME }}-${{ env.SHORT_SHA }} path: | ${{ github.workspace }}/*.pdf retention-days: 7 From 81f67f112fa65f8b6422f3f43faa6c597a9a65ff Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Thu, 27 Apr 2023 18:24:17 -0300 Subject: [PATCH 52/75] Update build-pdf.yml Signed-off-by: Rafael Sene --- .github/workflows/build-pdf.yml | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index e8a8be56..94372fd9 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -52,12 +52,21 @@ jobs: echo "SHORT_SHA=$(echo ${GITHUB_SHA::7})" >> $GITHUB_ENV echo "REPO_NAME=$(echo ${GITHUB_REPOSITORY##*/})" >> $GITHUB_ENV - # Upload the built PDF file as artifact - - name: Upload Build Artifact + # Upload the built PDF files as individual artifacts + - name: Upload Build Artifacts + run: | + for file in ${{ github.workspace }}/*.pdf; do + filename=$(basename "$file") + echo "Uploading $filename" + echo "ARTIFACT_NAME=$filename" >> $GITHUB_ENV + echo "ARTIFACT_PATH=$file" >> $GITHUB_ENV + done + + - name: Upload Artifact uses: actions/upload-artifact@v3 with: - path: | - ${{ github.workspace }}/*.pdf + name: ${{ env.ARTIFACT_NAME }} + path: ${{ env.ARTIFACT_PATH }} retention-days: 7 - name: Create Release From 296ec01f634f45d81e3afb22f9beca66b4cc6c96 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Tue, 6 Jun 2023 16:41:50 -0300 Subject: [PATCH 53/75] Upgrade the build process * Add the capability to set revision mark * Add the capability to build on container or directly on the host using the Makefile * Fix the document layout to show all 8 pages * Enable CI for all PRs and Commits Signed-off-by: Rafael Sene --- .github/workflows/build-pdf.yml | 92 ++++++++++------------ Makefile | 38 +++++++-- header.adoc | 20 +++-- readme.adoc | 131 ++++++++++++-------------------- 4 files changed, 128 insertions(+), 153 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 94372fd9..1939dee6 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -1,85 +1,73 @@ -name: Build Document PDF +name: Create Specification Document +# The workflow is triggered by pull request, push to main, and manual dispatch. on: workflow_dispatch: inputs: - release_type: - description: 'Release type (draft or regular)' - required: true - type: string - default: 'regular' version: description: 'Release version, e.g. X.Y.Z:' required: true type: string - target_branch: - description: 'Target branch to run the workflow on' - required: true - default: 'main' + revision_mark: + description: 'Set revision mark as Draft or Release:' + required: true + type: string + default: 'Draft' + prerelease: + description: 'Tag as a pre-release?' + required: false + type: boolean + default: true + draft: + description: 'Create release as a draft?' + required: false + type: boolean + default: false pull_request: - branches: - - '*' push: branches: - - '*' + - main jobs: build: runs-on: ubuntu-latest steps: - # Checkout the repository + # Step 1: Checkout the repository - name: Checkout repository uses: actions/checkout@v3 + with: + submodules: 'recursive' - # Pull the latest RISC-V Docs container image - # https://github.com/riscv/riscv-docs-base-container-image - # https://hub.docker.com/r/riscvintl/riscv-docs-base-container-image + # Step 2: Pull the latest RISC-V Docs container image - name: Pull Container - run: | - docker pull riscvintl/riscv-docs-base-container-image:latest + run: docker pull riscvintl/riscv-docs-base-container-image:latest - # Build PDF file using the container + # Step 3: Build Files - name: Build Files - id: build_files - run: | - docker run --rm -v ${{ github.workspace }}:/build riscvintl/riscv-docs-base-container-image:latest \ - /bin/sh -c 'make' - - # Set the short SHA and repo name for use in artifact names - - name: Set short SHA and repo name - run: | - echo "SHORT_SHA=$(echo ${GITHUB_SHA::7})" >> $GITHUB_ENV - echo "REPO_NAME=$(echo ${GITHUB_REPOSITORY##*/})" >> $GITHUB_ENV + run: make + env: + VERSION: v${{ github.event.inputs.version }} + REVMARK: ${{ github.event.inputs.revision_mark }} - # Upload the built PDF files as individual artifacts + # Step 4: Upload the built PDF files as a single artifact - name: Upload Build Artifacts - run: | - for file in ${{ github.workspace }}/*.pdf; do - filename=$(basename "$file") - echo "Uploading $filename" - echo "ARTIFACT_NAME=$filename" >> $GITHUB_ENV - echo "ARTIFACT_PATH=$file" >> $GITHUB_ENV - done - - - name: Upload Artifact uses: actions/upload-artifact@v3 with: - name: ${{ env.ARTIFACT_NAME }} - path: ${{ env.ARTIFACT_PATH }} - retention-days: 7 - + name: Build Artifacts + path: ${{ github.workspace }}/*.pdf + retention-days: 30 + + # Create Release - name: Create Release - if: steps.build_files.outcome == 'success' && github.event_name == 'workflow_dispatch' && github.event.inputs.release_type != '' uses: softprops/action-gh-release@v1 with: - draft: ${{ github.event.inputs.release_type == 'draft' }} + files: ${{ github.workspace }}/*.pdf tag_name: v${{ github.event.inputs.version }} - name: ${{ env.CURRENT_DATE }} - body: | - This release was created by: ${{ github.event.sender.login }} - Release Notes: ${{ github.event.inputs.release_notes }} - files: | - ${{ github.workspace }}/*.pdf + name: Release ${{ github.event.inputs.version }} + draft: ${{ github.event.inputs.draft }} + prerelease: ${{ github.event.inputs.prerelease }} env: GITHUB_TOKEN: ${{ secrets.GHTOKEN }} + if: github.event_name == 'workflow_dispatch' + # This condition ensures this step only runs for workflow_dispatch events. diff --git a/Makefile b/Makefile index 8de65a51..ad48dfe1 100644 --- a/Makefile +++ b/Makefile @@ -12,12 +12,22 @@ # This Makefile is designed to automate the process of building and packaging # the Doc Template for RISC-V Extensions. +DATE ?= $(shell date +%Y-%m-%d) +VERSION ?= v0.0.0 +REVMARK ?= Draft +DOCKER_RUN := docker run --rm -v ${PWD}:/build -w /build \ +riscvintl/riscv-docs-base-container-image:latest + HEADER_SOURCE := header.adoc PDF_RESULT := spec-sample.pdf ASCIIDOCTOR_PDF := asciidoctor-pdf -OPTIONS := --trace -a compress \ +OPTIONS := --trace \ + -a compress \ -a mathematical-format=svg \ + -a revnumber=${VERSION} \ + -a revremark=${REVMARK} \ + -a revdate=${DATE} \ -a pdf-fontsdir=docs-resources/fonts \ -a pdf-style=docs-resources/themes/riscv-pdf.yml \ --failure-level=ERROR @@ -25,15 +35,31 @@ REQUIRES := --require=asciidoctor-bibtex \ --require=asciidoctor-diagram \ --require=asciidoctor-mathematical -.PHONY: all build clean +.PHONY: all build clean build-container build-no-container all: build -build: - @echo "Building asciidoc" +build: + @echo "Checking if Docker is available..." + @if command -v docker &> /dev/null ; then \ + echo "Docker is available, building inside Docker container..."; \ + $(MAKE) build-container; \ + else \ + echo "Docker is not available, building without Docker..."; \ + $(MAKE) build-no-container; \ + fi + +build-container: + @echo "Starting build inside Docker container..." + $(DOCKER_RUN) /bin/sh -c "$(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) --out-file=$(PDF_RESULT) $(HEADER_SOURCE)" + @echo "Build completed successfully inside Docker container." + +build-no-container: + @echo "Starting build..." $(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) --out-file=$(PDF_RESULT) $(HEADER_SOURCE) + @echo "Build completed successfully." clean: - @echo "Cleaning up generated files" + @echo "Cleaning up generated files..." rm -f $(PDF_RESULT) - + @echo "Cleanup completed." \ No newline at end of file diff --git a/header.adoc b/header.adoc index 9c80801a..5fb12820 100644 --- a/header.adoc +++ b/header.adoc @@ -1,25 +1,24 @@ = RISC-V Example Specification Document (Zexmpl) -Author 1; Author 2; RISC-V Task Group - -[[header]] +Authors: Author 1, Author 2 +:docgroup: RISC-V Task Group :description: RISC-V Example Specification Document (Zexmpl) :company: RISC-V.org :revdate: 1/2023 :revnumber: 1.0 -:revremark: This document is in development. Assume everything can change. See http://riscv.org/spec-state for details. +:revremark: This document is under development. Expect potential changes. Visit http://riscv.org/spec-state for further details. +:revinfo: :url-riscv: http://riscv.org :doctype: book :preface-title: Preamble :colophon: :appendix-caption: Appendix -:imagesdir: images +:imagesdir: docs-resources/images :title-logo-image: image:risc-v_logo.png[pdfwidth=3.25in,align=center] // Settings: :experimental: :reproducible: -// needs to be changed? bug discussion started //:WaveDromEditorApp: app/wavedrom-editor.app -:imagesoutdir: images +:imagesoutdir: docs-resources/images :bibtex-file: example.bib :bibtex-order: alphabetical :bibtex-style: apa @@ -39,13 +38,12 @@ endif::[] :footnote: :xrefstyle: short -// Preamble [WARNING] .This document is in the link:http://riscv.org/spec-state[Development state] ==== -Assume everything can change. This draft specification will change before -being accepted as standard, so implementations made to this draft -specification will likely not conform to the future standard. +Expect potential changes. This draft specification is likely to evolve before +it is accepted as a standard. Implementations based on this draft +may not conform to the future standard. ==== [preface] diff --git a/readme.adoc b/readme.adoc index d66fb5b4..a88fe34e 100644 --- a/readme.adoc +++ b/readme.adoc @@ -1,96 +1,59 @@ -= RISC-V docs-spec-template += RISC-V Specification Template -This repository serves as a template for creating GitHub repositories within the RISC-V organization that are intended for developing specifications. +This repository serves as a blueprint for creating GitHub repositories within the RISC-V organization for the purpose of developing specifications. The template aims to facilitate and standardize the process of specification development. -**If you are reading this in a specification repository, please update the title for this section and provide a relevant introduction to your repository.** +NOTE: If you are viewing this in a specification repository, kindly update the title for this section and provide an introduction relevant to your repository. == License -This work is licensed under a Creative Commons Attribution 4.0 International License (CC-BY-4.0). -See the link:LICENSE[LICENSE] file for details. +This work is licensed under a Creative Commons Attribution 4.0 International License (CC-BY-4.0). For details, see the link:LICENSE[LICENSE] file. == Contributors -Contributors to this specification are contained in the link:contributors.adoc[contributors] file. +The list of contributors to this specification is maintained in the link:contributors.adoc[contributors] file. -For instructions on how to contribute please see the link:CONTRIBUTING.md[CONTRIBUTING] file. +For guidelines on how to contribute, refer to the link:CONTRIBUTING.md[CONTRIBUTING] file. == Building the Document -=== Building on Container - -To simplify the building process and avoid dealing with configurations and dependencies, you can build this documentation using a base container image, which contains everything you need. Follow these steps: - -Prerequisite: https://docs.docker.com/engine/install/[ensure you have Docker installed] - -1 - Clone the repository -``` -$ git clone https://github.com/riscv/docs-dev-guide.git -$ cd ./docs-dev-guide -``` -2 - Pull the RISC-V documentation base container image: -``` -$ docker pull riscvintl/riscv-docs-base-container-image:latest -``` -3 - Run the container and execute the build: -``` -$ docker run -it -v $(pwd)/docs-spec-template:/build riscvintl/riscv-docs-base-container-image:latest /bin/sh -c 'make' -``` -Output: -``` -Building asciidoc -asciidoctor-pdf \ - --attribute=mathematical-format=svg \ - --attribute=pdf-fontsdir=docs-resources/fonts \ - --attribute=pdf-style=docs-resources/themes/riscv-pdf.yml \ - --failure-level=ERROR \ - --require=asciidoctor-bibtex \ - --require=asciidoctor-diagram \ - --require=asciidoctor-mathematical \ - --out-file=example-spec.pdf \ - header.adoc -``` -4 - Clean -``` -docker run -it -v $(pwd):/build riscvintl/riscv-docs-base-container-image:latest /bin/sh -c 'make clean' -``` -=== Buidling on Local Machine - -==== Dependencies - -This project is built using AsciiDoctor (Ruby). The repository has been setup to build the PDF on -checkin using GitHub actions. Workflow dependencies are located in the `dependencies` directory. - -For more information on AsciiDoctor, specification guidelines, or building locally, see the -https://github.com/riscv/docs-dev-guide[RISC-V Documentation Developer Guide]. - -==== Cloning the project - -This project uses https://git-scm.com/book/en/v2/Git-Tools-Submodules[GitHub Submodules] -to include the https://github.com/riscv/docs-resources[RISC-V docs-resources project] -to achieve a common look and feel. - -When cloning this repository for the first time, you must either use -`git clone --recurse-submodules` or execute `git submodule init` and `git submodule update` after the clone to populate the docs-resources directory. Failure to clone the submodule, will result -in the PDF build fail with an error message like the following: - -``` -$ make -asciidoctor-pdf \ --a toc \ --a compress \ --a pdf-style=docs-resources/themes/riscv-pdf.yml \ --a pdf-fontsdir=docs-resources/fonts \ ---failure-level=ERROR \ --o profiles.pdf profiles.adoc - -asciidoctor: ERROR: could not locate or load the built-in pdf theme `docs-resources/themes/riscv-pdf.yml'; reverting to default theme -No such file or directory - notoserif-regular-subset.ttf not found in docs-resources/fonts - Use --trace for backtrace - -make: *** [Makefile:7: profiles.pdf] Error 1 -``` - -==== Building the document - -The final specification form of PDF can be generated using the `make` command. +=== Prerequisites + +To build the document, you'll need the following tools installed on your system: + +* Make +* asciiDoctor-pdf, asciidoctor-bibtex, asciidoctor-diagram and asciidoctor-mathematical +* Docker + +=== Clonning the Repository + +`git clone --recurse-submodules https://github.com/riscv/docs-spec-template.git` + +=== Building the Documentation + +To start the build process, run `cd ./docs-spec-template && make build`. + +The Makefile script will check the availability of Docker on your system: + +* If Docker is available, the documentation will be built inside a Docker container using the image riscvintl/riscv-docs-base-container-image:latest. This ensures a consistent build environment across different systems. +* If Docker is not available, the documentation will be built directly on your system using the installed tools. + +The documentation is generated from the AsciiDoctor source files in your project. The primary source file is specified by the `HEADER_SOURCE` variable in the Makefile. + +The build process utilizes several options, including theming and font settings, and generates a PDF document as output. + +=== Cleaning up + +To clean up the generated files, run `make clean`. This will remove the generated PDF file. + +== Versioning + +The `VERSION` variable is used to specify the revision number for the generated documentation. The default revision number is "v0.0.0". + +== Customization + +You can customize the build process by modifying the following variables in the Makefile: + +* `DATE`: Specifies the revision date for the generated documentation. The default value is the current date. +* `REVMARK`: Specifies the revision remark for the generated documentation. The default value is "Draft". +* `PDF_RESULT`: Specifies the name of the output PDF file. +* `DOCKER_RUN`: Defines the Docker run command used when Docker is available. \ No newline at end of file From e80e9f5bb4602f872c5d74d7c2c43cec50e1b18a Mon Sep 17 00:00:00 2001 From: Bill Traynor Date: Wed, 28 Jun 2023 10:57:58 -0400 Subject: [PATCH 54/75] Fixed a typo Cloning was spelled wrong. Signed-off-by: Bill Traynor --- readme.adoc | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/readme.adoc b/readme.adoc index a88fe34e..41566516 100644 --- a/readme.adoc +++ b/readme.adoc @@ -24,7 +24,7 @@ To build the document, you'll need the following tools installed on your system: * asciiDoctor-pdf, asciidoctor-bibtex, asciidoctor-diagram and asciidoctor-mathematical * Docker -=== Clonning the Repository +=== Cloning the Repository `git clone --recurse-submodules https://github.com/riscv/docs-spec-template.git` @@ -56,4 +56,4 @@ You can customize the build process by modifying the following variables in the * `DATE`: Specifies the revision date for the generated documentation. The default value is the current date. * `REVMARK`: Specifies the revision remark for the generated documentation. The default value is "Draft". * `PDF_RESULT`: Specifies the name of the output PDF file. -* `DOCKER_RUN`: Defines the Docker run command used when Docker is available. \ No newline at end of file +* `DOCKER_RUN`: Defines the Docker run command used when Docker is available. From 88ff3f93fe5d8fd2ca50d3f20692e0776b81819f Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Thu, 29 Jun 2023 17:55:48 -0300 Subject: [PATCH 55/75] Update build-pdf.yml Add an extra string for setting the revision mark to Stable. Signed-off-by: Rafael Sene --- .github/workflows/build-pdf.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 1939dee6..b7be4ddc 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -9,7 +9,7 @@ on: required: true type: string revision_mark: - description: 'Set revision mark as Draft or Release:' + description: 'Set revision mark as Draft, Release or Stable:' required: true type: string default: 'Draft' From 72fba362738ed61bd784da3f749ef9fdebf20ff1 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Thu, 29 Jun 2023 18:37:12 -0300 Subject: [PATCH 56/75] Update readme.adoc Signed-off-by: Rafael Sene --- readme.adoc | 33 ++++++++++++++++++++------------- 1 file changed, 20 insertions(+), 13 deletions(-) diff --git a/readme.adoc b/readme.adoc index 41566516..d0365564 100644 --- a/readme.adoc +++ b/readme.adoc @@ -28,6 +28,26 @@ To build the document, you'll need the following tools installed on your system: `git clone --recurse-submodules https://github.com/riscv/docs-spec-template.git` +=== Versioning, Customization and Makefile Variables + +This section provides an overview of the environment variables used in our Makefile. These variables include DATE, VERSION, and REVMARK. + +* `DATE`: Represents the current date. The default value is generated using the date command on Unix-based systems, formatted as "YYYY-MM-DD". +* `VERSION`: Represents the version of the specification being built. By default, this is set to 'v0.0.0'. You can change this to a different value, like 'v1.0.0', 'v1.1.0', etc., based on the current version of your specification. +* `REVMARK`: This represents a revision marker for the project. Its default value is 'Draft'. You may want to change this to something like 'Release' or 'Stable'. +* `PDF_RESULT`: Specifies the name of the output PDF file. +* `DOCKER_RUN`: Defines the Docker run command used when Docker is available. + +==== Setting Environment Variables + +These variables can be overridden by setting environment variables on your system. Here's how you can do it in Linux and MacOS: + +```bash +export VERSION=v1.2.3 +export REVMARK=Release +export PDF_RESULT=spec.pdf +``` + === Building the Documentation To start the build process, run `cd ./docs-spec-template && make build`. @@ -44,16 +64,3 @@ The build process utilizes several options, including theming and font settings, === Cleaning up To clean up the generated files, run `make clean`. This will remove the generated PDF file. - -== Versioning - -The `VERSION` variable is used to specify the revision number for the generated documentation. The default revision number is "v0.0.0". - -== Customization - -You can customize the build process by modifying the following variables in the Makefile: - -* `DATE`: Specifies the revision date for the generated documentation. The default value is the current date. -* `REVMARK`: Specifies the revision remark for the generated documentation. The default value is "Draft". -* `PDF_RESULT`: Specifies the name of the output PDF file. -* `DOCKER_RUN`: Defines the Docker run command used when Docker is available. From deebd2c6fa0f54fc2d4a710f8432b14b958e0fdd Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Thu, 29 Jun 2023 20:03:55 -0300 Subject: [PATCH 57/75] Update readme.adoc Add versioning strategy explanation Signed-off-by: Rafael Sene --- readme.adoc | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) diff --git a/readme.adoc b/readme.adoc index d0365564..dbc4538f 100644 --- a/readme.adoc +++ b/readme.adoc @@ -38,6 +38,50 @@ This section provides an overview of the environment variables used in our Makef * `PDF_RESULT`: Specifies the name of the output PDF file. * `DOCKER_RUN`: Defines the Docker run command used when Docker is available. +==== Versioning Strategy + +In a nutshell, the versioning strategy is as follows: + +```bash +[Start] + | + V +1.0.0-draft[#] --> (Revisions) --> 1.0.0-draft[#] (last draft) + | + V +1.0.0-rc[#] --> (Revisions) --> 1.0.0-rc[#] (last release candidate) + | + V +[Approval] + | + V +1.0.0 (Approved/Ratified) + | + V +(Minor changes, Fixes, Compatible extensions) --> 1.1.0 + | + V +(Corrections, Editorial changes) --> 1.1.1 + | + V +(Incompatible changes, Major new features) --> 2.0.0 +``` + +link:https://docs.google.com/document/d/1ZO3clTdgbm-t6r8GMDQ7CypWl68_3ZeYuHl4e-cS280/edit[RISC-V International has a policy for versioning] +. The purpose of this policy is to ensure consistency and clarity in the versioning of RISC-V artifacts, which can be comprehended by both the RISC-V community and external parties. This policy adheres to Semantic Versioning 2.0.0 (MAJOR.MINOR.PATCH). + +The first ratified version of any artifact is expected to be 1.0.0. The policy outlines specific versioning conventions for different stages of specification development: 1.0.0-draft1 for drafts, 1.0.0-rc1 for release candidates, and 1.0.0 for approved and ratified specifications. Furthermore, the use of build-date metadata is encouraged for non-release versions. + +The MAJOR.MINOR.PATCH paradigm is explained as: PATCH for corrections or editorial changes, MINOR for fixes and compatible extensions with limited new functionality, and MAJOR for incompatible changes or significant new features. The policy is effective immediately upon approval. + +Examples: + +* Specification Development - Suppose a new RISC-V specification is being developed. Its version might start as 1.0.0-draft1 for the first draft, then proceed to 1.0.0-rc1 when it reaches the release candidate stage (1.0.0-rc2, 1.0.0-rc3, etc...), and finally settle at 1.0.0 when it's approved and ratified. + +* Update Types - If the ratified specification undergoes a minor update, incorporating fixes or compatible extensions with limited new functionality, it would change to 1.1.0. If there are only corrections or editorial modifications, the version would move to 1.0.1. For incompatible changes or major new features, the version would leap to 2.0.0. + +* Metadata Tagging - Non-release versions of the specification can be tagged with the build date. For example, if a draft version is prepared on June 29, 2023, it could be tagged as 1.0.0-draft1+20230629. + ==== Setting Environment Variables These variables can be overridden by setting environment variables on your system. Here's how you can do it in Linux and MacOS: From 26fbafb26837e3e22ca4d7dbafdcc1408f668be7 Mon Sep 17 00:00:00 2001 From: Tsukasa OI Date: Fri, 8 Sep 2023 06:41:29 +0000 Subject: [PATCH 58/75] Detect Docker robustly "&> /dev/null" works as a redirection from stdout/stderr to /dev/null in Bash but not in POSIX shell (considered as an asynchronous execution and the result of the "command" command cannot be retrieved). As a result, it always assumes that Docker always exists. This commit makes the redirection robust and portable (makes it possible to detect "no Docker" condition correctly). Signed-off-by: Tsukasa OI --- Makefile | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Makefile b/Makefile index ad48dfe1..2e220f14 100644 --- a/Makefile +++ b/Makefile @@ -41,7 +41,7 @@ all: build build: @echo "Checking if Docker is available..." - @if command -v docker &> /dev/null ; then \ + @if command -v docker >/dev/null 2>&1 ; then \ echo "Docker is available, building inside Docker container..."; \ $(MAKE) build-container; \ else \ @@ -62,4 +62,4 @@ build-no-container: clean: @echo "Cleaning up generated files..." rm -f $(PDF_RESULT) - @echo "Cleanup completed." \ No newline at end of file + @echo "Cleanup completed." From b20864dd21802241ab4d7d4a6efcfa60ea49ed1e Mon Sep 17 00:00:00 2001 From: Jeff Scheel Date: Fri, 20 Oct 2023 14:25:47 -0400 Subject: [PATCH 59/75] Update copyright year to 2023. Signed-off-by: Jeff Scheel --- header.adoc | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/header.adoc b/header.adoc index 5fb12820..662789d9 100644 --- a/header.adoc +++ b/header.adoc @@ -53,7 +53,7 @@ Attribution 4.0 International License (CC-BY 4.0). The full license text is available at https://creativecommons.org/licenses/by/4.0/. -Copyright 2022 by RISC-V International. +Copyright 2023 by RISC-V International. [preface] include::contributors.adoc[] @@ -63,4 +63,4 @@ include::chapter2.adoc[] // The index must precede the bibliography include::index.adoc[] -include::bibliography.adoc[] \ No newline at end of file +include::bibliography.adoc[] From 12967e04fdd4c45e16d92e4af5ce81b3fea9313b Mon Sep 17 00:00:00 2001 From: Henry Hsieh Date: Sat, 9 Dec 2023 14:41:55 +0800 Subject: [PATCH 60/75] Fix asciidoctor-pdf theme attribute Signed-off-by: Henry Hsieh --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 2e220f14..a46d659c 100644 --- a/Makefile +++ b/Makefile @@ -29,7 +29,7 @@ OPTIONS := --trace \ -a revremark=${REVMARK} \ -a revdate=${DATE} \ -a pdf-fontsdir=docs-resources/fonts \ - -a pdf-style=docs-resources/themes/riscv-pdf.yml \ + -a pdf-theme=docs-resources/themes/riscv-pdf.yml \ --failure-level=ERROR REQUIRES := --require=asciidoctor-bibtex \ --require=asciidoctor-diagram \ From 55b86c1022b29d421f05aa7378b413839f52961c Mon Sep 17 00:00:00 2001 From: Bill Traynor Date: Mon, 11 Dec 2023 15:00:25 -0500 Subject: [PATCH 61/75] Pulling in newer submodule. Updated submodule. --- docs-resources | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs-resources b/docs-resources index 6a2d5b1f..8abc9340 160000 --- a/docs-resources +++ b/docs-resources @@ -1 +1 @@ -Subproject commit 6a2d5b1f929e0e25df0c832b522ed1fc0c78e325 +Subproject commit 8abc93401a61e52c460888ff658518a56e37ee9c From e47f680c413090d237afd9c80aa5a7d383fd5987 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Fri, 5 Jan 2024 18:32:16 -0300 Subject: [PATCH 62/75] Update README --- readme.adoc | 64 ----------------------------------------------------- 1 file changed, 64 deletions(-) diff --git a/readme.adoc b/readme.adoc index dbc4538f..4c598058 100644 --- a/readme.adoc +++ b/readme.adoc @@ -28,70 +28,6 @@ To build the document, you'll need the following tools installed on your system: `git clone --recurse-submodules https://github.com/riscv/docs-spec-template.git` -=== Versioning, Customization and Makefile Variables - -This section provides an overview of the environment variables used in our Makefile. These variables include DATE, VERSION, and REVMARK. - -* `DATE`: Represents the current date. The default value is generated using the date command on Unix-based systems, formatted as "YYYY-MM-DD". -* `VERSION`: Represents the version of the specification being built. By default, this is set to 'v0.0.0'. You can change this to a different value, like 'v1.0.0', 'v1.1.0', etc., based on the current version of your specification. -* `REVMARK`: This represents a revision marker for the project. Its default value is 'Draft'. You may want to change this to something like 'Release' or 'Stable'. -* `PDF_RESULT`: Specifies the name of the output PDF file. -* `DOCKER_RUN`: Defines the Docker run command used when Docker is available. - -==== Versioning Strategy - -In a nutshell, the versioning strategy is as follows: - -```bash -[Start] - | - V -1.0.0-draft[#] --> (Revisions) --> 1.0.0-draft[#] (last draft) - | - V -1.0.0-rc[#] --> (Revisions) --> 1.0.0-rc[#] (last release candidate) - | - V -[Approval] - | - V -1.0.0 (Approved/Ratified) - | - V -(Minor changes, Fixes, Compatible extensions) --> 1.1.0 - | - V -(Corrections, Editorial changes) --> 1.1.1 - | - V -(Incompatible changes, Major new features) --> 2.0.0 -``` - -link:https://docs.google.com/document/d/1ZO3clTdgbm-t6r8GMDQ7CypWl68_3ZeYuHl4e-cS280/edit[RISC-V International has a policy for versioning] -. The purpose of this policy is to ensure consistency and clarity in the versioning of RISC-V artifacts, which can be comprehended by both the RISC-V community and external parties. This policy adheres to Semantic Versioning 2.0.0 (MAJOR.MINOR.PATCH). - -The first ratified version of any artifact is expected to be 1.0.0. The policy outlines specific versioning conventions for different stages of specification development: 1.0.0-draft1 for drafts, 1.0.0-rc1 for release candidates, and 1.0.0 for approved and ratified specifications. Furthermore, the use of build-date metadata is encouraged for non-release versions. - -The MAJOR.MINOR.PATCH paradigm is explained as: PATCH for corrections or editorial changes, MINOR for fixes and compatible extensions with limited new functionality, and MAJOR for incompatible changes or significant new features. The policy is effective immediately upon approval. - -Examples: - -* Specification Development - Suppose a new RISC-V specification is being developed. Its version might start as 1.0.0-draft1 for the first draft, then proceed to 1.0.0-rc1 when it reaches the release candidate stage (1.0.0-rc2, 1.0.0-rc3, etc...), and finally settle at 1.0.0 when it's approved and ratified. - -* Update Types - If the ratified specification undergoes a minor update, incorporating fixes or compatible extensions with limited new functionality, it would change to 1.1.0. If there are only corrections or editorial modifications, the version would move to 1.0.1. For incompatible changes or major new features, the version would leap to 2.0.0. - -* Metadata Tagging - Non-release versions of the specification can be tagged with the build date. For example, if a draft version is prepared on June 29, 2023, it could be tagged as 1.0.0-draft1+20230629. - -==== Setting Environment Variables - -These variables can be overridden by setting environment variables on your system. Here's how you can do it in Linux and MacOS: - -```bash -export VERSION=v1.2.3 -export REVMARK=Release -export PDF_RESULT=spec.pdf -``` - === Building the Documentation To start the build process, run `cd ./docs-spec-template && make build`. From 673be9f425fd67a09b9b3e56a113e1b19185bb9e Mon Sep 17 00:00:00 2001 From: Bill Traynor Date: Thu, 18 Jan 2024 10:20:23 -0500 Subject: [PATCH 63/75] Adding copy buttons to code blocks. Making the code blocks copyable. Signed-off-by: Bill Traynor --- readme.adoc | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/readme.adoc b/readme.adoc index 4c598058..74727d80 100644 --- a/readme.adoc +++ b/readme.adoc @@ -25,12 +25,15 @@ To build the document, you'll need the following tools installed on your system: * Docker === Cloning the Repository - -`git clone --recurse-submodules https://github.com/riscv/docs-spec-template.git` - +``` +git clone --recurse-submodules https://github.com/riscv/docs-spec-template.git +``` === Building the Documentation -To start the build process, run `cd ./docs-spec-template && make build`. +To start the build process, run: +``` +cd ./docs-spec-template && make build +``` The Makefile script will check the availability of Docker on your system: @@ -43,4 +46,8 @@ The build process utilizes several options, including theming and font settings, === Cleaning up -To clean up the generated files, run `make clean`. This will remove the generated PDF file. +To clean up the generated files, run: +``` +make clean +``` +This will remove the generated PDF file. From 53c54751e24ddcd255d477027ce2b52d3ed0a718 Mon Sep 17 00:00:00 2001 From: Kevin Broch Date: Thu, 18 Jan 2024 13:49:28 -0800 Subject: [PATCH 64/75] initial add of pre-commit tool for linting source * add basic source checks for existing file types * commit fixes from auto-corrections (eoln and eof fixes) * add github action to run pre-commit hooks in CI Signed-off-by: Kevin Broch --- .github/workflows/build-pdf.yml | 6 +++--- .github/workflows/pre-commit.yml | 14 ++++++++++++++ .gitignore | 1 - .pre-commit-config.yaml | 10 ++++++++++ CONTRIBUTING.md | 2 +- LICENSE | 3 +-- Makefile | 6 +++--- example.bib | 2 +- 8 files changed, 33 insertions(+), 11 deletions(-) create mode 100644 .github/workflows/pre-commit.yml create mode 100644 .pre-commit-config.yaml diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index b7be4ddc..6eecf0de 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -8,7 +8,7 @@ on: description: 'Release version, e.g. X.Y.Z:' required: true type: string - revision_mark: + revision_mark: description: 'Set revision mark as Draft, Release or Stable:' required: true type: string @@ -57,7 +57,7 @@ jobs: name: Build Artifacts path: ${{ github.workspace }}/*.pdf retention-days: 30 - + # Create Release - name: Create Release uses: softprops/action-gh-release@v1 @@ -69,5 +69,5 @@ jobs: prerelease: ${{ github.event.inputs.prerelease }} env: GITHUB_TOKEN: ${{ secrets.GHTOKEN }} - if: github.event_name == 'workflow_dispatch' + if: github.event_name == 'workflow_dispatch' # This condition ensures this step only runs for workflow_dispatch events. diff --git a/.github/workflows/pre-commit.yml b/.github/workflows/pre-commit.yml new file mode 100644 index 00000000..c2f7e71f --- /dev/null +++ b/.github/workflows/pre-commit.yml @@ -0,0 +1,14 @@ +name: pre-commit + +on: + pull_request: + push: + branches: [main] + +jobs: + pre-commit: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - uses: actions/setup-python@v3 + - uses: pre-commit/action@v3.0.0 diff --git a/.gitignore b/.gitignore index bd98a737..a1363379 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1 @@ *.pdf - diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml new file mode 100644 index 00000000..d174cf92 --- /dev/null +++ b/.pre-commit-config.yaml @@ -0,0 +1,10 @@ +repos: +- repo: https://github.com/pre-commit/pre-commit-hooks + rev: v4.5.0 + hooks: + - id: check-json + - id: check-symlinks + - id: check-yaml + - id: end-of-file-fixer + - id: trailing-whitespace + args: [--markdown-linebreak-ext=md] diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 3c79557a..1d98c72b 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -55,4 +55,4 @@ You can manually add the DCO text to your commit body or include either -s or -- Note: -Ensure that the name and email address associated with your GitHub account match the name and email address in the Signed-off-by line of your commit message. \ No newline at end of file +Ensure that the name and email address associated with your GitHub account match the name and email address in the Signed-off-by line of your commit message. diff --git a/LICENSE b/LICENSE index 53883b1c..2f244ac8 100644 --- a/LICENSE +++ b/LICENSE @@ -49,7 +49,7 @@ exhaustive, and do not form part of our licenses. such as asking that all changes be marked or described. Although not required by our licenses, you are encouraged to respect those requests where reasonable. More_considerations - for the public: + for the public: wiki.creativecommons.org/Considerations_for_licensees ======================================================================= @@ -393,4 +393,3 @@ the avoidance of doubt, this paragraph does not form part of the public licenses. Creative Commons may be contacted at creativecommons.org. - diff --git a/Makefile b/Makefile index a46d659c..5b0b05ac 100644 --- a/Makefile +++ b/Makefile @@ -8,8 +8,8 @@ # SPDX-License-Identifier: CC-BY-SA-4.0 # # Description: -# -# This Makefile is designed to automate the process of building and packaging +# +# This Makefile is designed to automate the process of building and packaging # the Doc Template for RISC-V Extensions. DATE ?= $(shell date +%Y-%m-%d) @@ -39,7 +39,7 @@ REQUIRES := --require=asciidoctor-bibtex \ all: build -build: +build: @echo "Checking if Docker is available..." @if command -v docker >/dev/null 2>&1 ; then \ echo "Docker is available, building inside Docker container..."; \ diff --git a/example.bib b/example.bib index 9da24b15..4c368b14 100644 --- a/example.bib +++ b/example.bib @@ -33,4 +33,4 @@ @article{spur-jsscc1989 number = {6}, pages = {1688-1698}, month = {December} -} \ No newline at end of file +} From d307ec047e3a7689cef29006dd8c5d919c478ee1 Mon Sep 17 00:00:00 2001 From: Kevin Broch Date: Fri, 19 Jan 2024 08:44:59 -0800 Subject: [PATCH 65/75] disallow other file extensions for asciidoc other than .adoc #20 Signed-off-by: Kevin Broch --- .pre-commit-config.yaml | 27 ++++++++++++++++++--------- 1 file changed, 18 insertions(+), 9 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index d174cf92..b292c124 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -1,10 +1,19 @@ repos: -- repo: https://github.com/pre-commit/pre-commit-hooks - rev: v4.5.0 - hooks: - - id: check-json - - id: check-symlinks - - id: check-yaml - - id: end-of-file-fixer - - id: trailing-whitespace - args: [--markdown-linebreak-ext=md] +- repo: https://github.com/pre-commit/pre-commit-hooks + rev: v4.5.0 + hooks: + - id: check-json + - id: check-symlinks + - id: check-yaml + - id: end-of-file-fixer + - id: trailing-whitespace + args: [--markdown-linebreak-ext=md] + +- repo: local + hooks: + - id: forbidden-file-extensions + name: forbidden-file-extensions + entry: disallow these file extensions + language: fail + # Disallow other asciidoc extensions except .adoc + files: .*\.(asciidoc|asc)$ From 7a44cfbdaae5c78b75066825ba95f6b48c0a440a Mon Sep 17 00:00:00 2001 From: Kevin Broch Date: Fri, 19 Jan 2024 11:56:11 -0800 Subject: [PATCH 66/75] add yamlfmt pre-commit hook also autofix of existing files fixes #22 Signed-off-by: Kevin Broch --- .github/workflows/build-pdf.yml | 81 ++++++++++++++++---------------- .github/workflows/pre-commit.yml | 7 +-- .pre-commit-config.yaml | 41 +++++++++------- 3 files changed, 69 insertions(+), 60 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 6eecf0de..580c908a 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -1,3 +1,4 @@ +--- name: Create Specification Document # The workflow is triggered by pull request, push to main, and manual dispatch. @@ -9,17 +10,17 @@ on: required: true type: string revision_mark: - description: 'Set revision mark as Draft, Release or Stable:' - required: true - type: string - default: 'Draft' + description: 'Set revision mark as Draft, Release or Stable:' + required: true + type: string + default: Draft prerelease: - description: 'Tag as a pre-release?' + description: Tag as a pre-release? required: false type: boolean default: true draft: - description: 'Create release as a draft?' + description: Create release as a draft? required: false type: boolean default: false @@ -33,41 +34,41 @@ jobs: runs-on: ubuntu-latest steps: - # Step 1: Checkout the repository - - name: Checkout repository - uses: actions/checkout@v3 - with: - submodules: 'recursive' + # Step 1: Checkout the repository + - name: Checkout repository + uses: actions/checkout@v3 + with: + submodules: recursive - # Step 2: Pull the latest RISC-V Docs container image - - name: Pull Container - run: docker pull riscvintl/riscv-docs-base-container-image:latest + # Step 2: Pull the latest RISC-V Docs container image + - name: Pull Container + run: docker pull riscvintl/riscv-docs-base-container-image:latest - # Step 3: Build Files - - name: Build Files - run: make - env: - VERSION: v${{ github.event.inputs.version }} - REVMARK: ${{ github.event.inputs.revision_mark }} + # Step 3: Build Files + - name: Build Files + run: make + env: + VERSION: v${{ github.event.inputs.version }} + REVMARK: ${{ github.event.inputs.revision_mark }} - # Step 4: Upload the built PDF files as a single artifact - - name: Upload Build Artifacts - uses: actions/upload-artifact@v3 - with: - name: Build Artifacts - path: ${{ github.workspace }}/*.pdf - retention-days: 30 + # Step 4: Upload the built PDF files as a single artifact + - name: Upload Build Artifacts + uses: actions/upload-artifact@v3 + with: + name: Build Artifacts + path: ${{ github.workspace }}/*.pdf + retention-days: 30 - # Create Release - - name: Create Release - uses: softprops/action-gh-release@v1 - with: - files: ${{ github.workspace }}/*.pdf - tag_name: v${{ github.event.inputs.version }} - name: Release ${{ github.event.inputs.version }} - draft: ${{ github.event.inputs.draft }} - prerelease: ${{ github.event.inputs.prerelease }} - env: - GITHUB_TOKEN: ${{ secrets.GHTOKEN }} - if: github.event_name == 'workflow_dispatch' - # This condition ensures this step only runs for workflow_dispatch events. + # Create Release + - name: Create Release + uses: softprops/action-gh-release@v1 + with: + files: ${{ github.workspace }}/*.pdf + tag_name: v${{ github.event.inputs.version }} + name: Release ${{ github.event.inputs.version }} + draft: ${{ github.event.inputs.draft }} + prerelease: ${{ github.event.inputs.prerelease }} + env: + GITHUB_TOKEN: ${{ secrets.GHTOKEN }} + if: github.event_name == 'workflow_dispatch' + # This condition ensures this step only runs for workflow_dispatch events. diff --git a/.github/workflows/pre-commit.yml b/.github/workflows/pre-commit.yml index c2f7e71f..2126ca60 100644 --- a/.github/workflows/pre-commit.yml +++ b/.github/workflows/pre-commit.yml @@ -1,3 +1,4 @@ +--- name: pre-commit on: @@ -9,6 +10,6 @@ jobs: pre-commit: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 - - uses: actions/setup-python@v3 - - uses: pre-commit/action@v3.0.0 + - uses: actions/checkout@v3 + - uses: actions/setup-python@v3 + - uses: pre-commit/action@v3.0.0 diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index b292c124..63fae1b6 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -1,19 +1,26 @@ +--- repos: -- repo: https://github.com/pre-commit/pre-commit-hooks - rev: v4.5.0 - hooks: - - id: check-json - - id: check-symlinks - - id: check-yaml - - id: end-of-file-fixer - - id: trailing-whitespace - args: [--markdown-linebreak-ext=md] + - repo: https://github.com/pre-commit/pre-commit-hooks + rev: v4.5.0 + hooks: + - id: check-json + - id: check-symlinks + - id: check-yaml + - id: end-of-file-fixer + - id: trailing-whitespace + args: [--markdown-linebreak-ext=md] -- repo: local - hooks: - - id: forbidden-file-extensions - name: forbidden-file-extensions - entry: disallow these file extensions - language: fail - # Disallow other asciidoc extensions except .adoc - files: .*\.(asciidoc|asc)$ + - repo: local + hooks: + - id: forbidden-file-extensions + name: forbidden-file-extensions + entry: disallow these file extensions + language: fail + # Disallow other asciidoc extensions except .adoc + files: .*\.(asciidoc|asc)$ + + - repo: https://github.com/jumanjihouse/pre-commit-hook-yamlfmt + rev: 0.2.3 + hooks: + - id: yamlfmt + args: [--mapping, '2', --sequence, '4', --offset, '2'] From 06c349d1bf4bffd8ef27430f6244da800a20a39a Mon Sep 17 00:00:00 2001 From: Kevin Broch Date: Sat, 20 Jan 2024 09:26:04 -0800 Subject: [PATCH 67/75] add html output fixes #18 Signed-off-by: Kevin Broch --- Makefile | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 5b0b05ac..52107638 100644 --- a/Makefile +++ b/Makefile @@ -20,8 +20,10 @@ riscvintl/riscv-docs-base-container-image:latest HEADER_SOURCE := header.adoc PDF_RESULT := spec-sample.pdf +HTML_RESULT := spec-sample.html ASCIIDOCTOR_PDF := asciidoctor-pdf +ASCIIDOCTOR_HTML := asciidoctor OPTIONS := --trace \ -a compress \ -a mathematical-format=svg \ @@ -52,14 +54,16 @@ build: build-container: @echo "Starting build inside Docker container..." $(DOCKER_RUN) /bin/sh -c "$(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) --out-file=$(PDF_RESULT) $(HEADER_SOURCE)" + $(DOCKER_RUN) /bin/sh -c "$(ASCIIDOCTOR_HTML) $(OPTIONS) $(REQUIRES) --out-file=$(HTML_RESULT) $(HEADER_SOURCE)" @echo "Build completed successfully inside Docker container." build-no-container: @echo "Starting build..." $(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) --out-file=$(PDF_RESULT) $(HEADER_SOURCE) + $(ASCIIDOCTOR_HTML) $(OPTIONS) $(REQUIRES) --out-file=$(HTML_RESULT) $(HEADER_SOURCE) @echo "Build completed successfully." clean: @echo "Cleaning up generated files..." - rm -f $(PDF_RESULT) + rm -f $(PDF_RESULT) $(HTML_RESULT) @echo "Cleanup completed." From a83571bc147b5464e0676c0629418b91d09cd741 Mon Sep 17 00:00:00 2001 From: Kevin Broch Date: Mon, 22 Jan 2024 18:51:08 -0800 Subject: [PATCH 68/75] move asciidoc source files to src; build docs in build dir relates to #25 Signed-off-by: Kevin Broch --- .gitignore | 2 +- Makefile | 10 ++++++---- images/risc-v_logo.png | Bin 32482 -> 0 bytes readme.adoc | 2 +- bibliography.adoc => src/bibliography.adoc | 0 chapter2.adoc => src/chapter2.adoc | 0 contributors.adoc => src/contributors.adoc | 0 header.adoc => src/header.adoc | 7 ++++--- index.adoc => src/index.adoc | 0 intro.adoc => src/intro.adoc | 0 10 files changed, 12 insertions(+), 9 deletions(-) delete mode 100755 images/risc-v_logo.png rename bibliography.adoc => src/bibliography.adoc (100%) rename chapter2.adoc => src/chapter2.adoc (100%) rename contributors.adoc => src/contributors.adoc (100%) rename header.adoc => src/header.adoc (87%) rename index.adoc => src/index.adoc (100%) rename intro.adoc => src/intro.adoc (100%) diff --git a/.gitignore b/.gitignore index a1363379..d9b4f015 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1 @@ -*.pdf +/build/* diff --git a/Makefile b/Makefile index 52107638..3df8b68f 100644 --- a/Makefile +++ b/Makefile @@ -18,9 +18,11 @@ REVMARK ?= Draft DOCKER_RUN := docker run --rm -v ${PWD}:/build -w /build \ riscvintl/riscv-docs-base-container-image:latest -HEADER_SOURCE := header.adoc -PDF_RESULT := spec-sample.pdf -HTML_RESULT := spec-sample.html +SRC_DIR := src +BUILD_DIR := build +HEADER_SOURCE := $(SRC_DIR)/header.adoc +PDF_RESULT := $(BUILD_DIR)/spec-sample.pdf +HTML_RESULT := $(BUILD_DIR)/spec-sample.html ASCIIDOCTOR_PDF := asciidoctor-pdf ASCIIDOCTOR_HTML := asciidoctor @@ -65,5 +67,5 @@ build-no-container: clean: @echo "Cleaning up generated files..." - rm -f $(PDF_RESULT) $(HTML_RESULT) + rm -rf $(BUILD_DIR) @echo "Cleanup completed." diff --git a/images/risc-v_logo.png b/images/risc-v_logo.png deleted file mode 100755 index 4e826b2d2ff2e5ed8a5f8e6305618684aa79470e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 32482 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 Date: Tue, 23 Jan 2024 10:44:23 -0800 Subject: [PATCH 69/75] Add directory structure description to readme related to #26 other minor edits: * minor wording changes * add line spacing between blocks * add `shell` to code blocks Signed-off-by: Kevin Broch --- readme.adoc | 26 +++++++++++++++++++------- 1 file changed, 19 insertions(+), 7 deletions(-) diff --git a/readme.adoc b/readme.adoc index c4af2da3..68f2461a 100644 --- a/readme.adoc +++ b/readme.adoc @@ -1,6 +1,6 @@ = RISC-V Specification Template -This repository serves as a blueprint for creating GitHub repositories within the RISC-V organization for the purpose of developing specifications. The template aims to facilitate and standardize the process of specification development. +This repository serves as a template for creating GitHub repositories within the RISC-V organization for the purpose of developing specifications. It aims to facilitate and standardize the process of specification development. NOTE: If you are viewing this in a specification repository, kindly update the title for this section and provide an introduction relevant to your repository. @@ -16,26 +16,38 @@ For guidelines on how to contribute, refer to the link:CONTRIBUTING.md[CONTRIBUT == Building the Document +=== Directory Structure + +The following directories are used to organize the contents of this repo: + +* `dependencies/`: software dependencies needed to build the specification +* `docs-resources/`: resources for all specifications sourced from link:.gitmodules[git submodule] +* `src/`: source files for the specification +* `build/`: default directory where the build artifacts are generated + === Prerequisites To build the document, you'll need the following tools installed on your system: * Make -* asciiDoctor-pdf, asciidoctor-bibtex, asciidoctor-diagram and asciidoctor-mathematical +* asciiDoctor-pdf, asciidoctor-bibtex, asciidoctor-diagram, and asciidoctor-mathematical * Docker === Cloning the Repository -``` + +```shell git clone --recurse-submodules https://github.com/riscv/docs-spec-template.git ``` + === Building the Documentation To start the build process, run: -``` + +```shell cd ./docs-spec-template && make build ``` -The Makefile script will check the availability of Docker on your system: +The link:Makefile[] script will check the availability of Docker on your system: * If Docker is available, the documentation will be built inside a Docker container using the image riscvintl/riscv-docs-base-container-image:latest. This ensures a consistent build environment across different systems. * If Docker is not available, the documentation will be built directly on your system using the installed tools. @@ -47,7 +59,7 @@ The build process utilizes several options, including theming and font settings, === Cleaning up To clean up the generated files, run: -``` + +```shell make clean ``` -This will remove the generated PDF file. From 44e253ba710e63573c58f22f1916cd11f6a5330b Mon Sep 17 00:00:00 2001 From: Kevin Broch Date: Tue, 23 Jan 2024 13:23:29 -0800 Subject: [PATCH 70/75] Forgot to move example.bib into the src dir relates to #25 Signed-off-by: Kevin Broch --- example.bib => src/example.bib | 0 src/header.adoc | 3 ++- 2 files changed, 2 insertions(+), 1 deletion(-) rename example.bib => src/example.bib (100%) diff --git a/example.bib b/src/example.bib similarity index 100% rename from example.bib rename to src/example.bib diff --git a/src/header.adoc b/src/header.adoc index 53e3e073..5419bf16 100644 --- a/src/header.adoc +++ b/src/header.adoc @@ -20,7 +20,8 @@ Authors: Author 1, Author 2 :reproducible: //:WaveDromEditorApp: app/wavedrom-editor.app :imagesoutdir: ../build/images -:bibtex-file: example.bib +:srcdir: src +:bibtex-file: {srcdir}/example.bib :bibtex-order: alphabetical :bibtex-style: apa :icons: font From 15c664969b5ddb9fcbd88ab376016dd07a47d438 Mon Sep 17 00:00:00 2001 From: Kevin Broch Date: Tue, 23 Jan 2024 19:08:06 -0800 Subject: [PATCH 71/75] bump docs-resource submodule to latest Signed-off-by: Kevin Broch --- docs-resources | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs-resources b/docs-resources index 8abc9340..66f972d7 160000 --- a/docs-resources +++ b/docs-resources @@ -1 +1 @@ -Subproject commit 8abc93401a61e52c460888ff658518a56e37ee9c +Subproject commit 66f972d7dc961551a7815d2fceb82fbea7ce2c44 From ee0acb5ccef3cc78f17e9584f232e4d09d8b575b Mon Sep 17 00:00:00 2001 From: Kevin Broch Date: Tue, 23 Jan 2024 20:45:21 -0800 Subject: [PATCH 72/75] refactor makefile: add var to inject asciidoctor options; change to build dir instead of outfile Signed-off-by: Kevin Broch --- Makefile | 16 ++++++++-------- docs-resources | 2 +- src/{header.adoc => spec-sample.adoc} | 0 3 files changed, 9 insertions(+), 9 deletions(-) rename src/{header.adoc => spec-sample.adoc} (100%) diff --git a/Makefile b/Makefile index 3df8b68f..d7d0d413 100644 --- a/Makefile +++ b/Makefile @@ -20,10 +20,8 @@ riscvintl/riscv-docs-base-container-image:latest SRC_DIR := src BUILD_DIR := build -HEADER_SOURCE := $(SRC_DIR)/header.adoc -PDF_RESULT := $(BUILD_DIR)/spec-sample.pdf -HTML_RESULT := $(BUILD_DIR)/spec-sample.html - +HEADER_SOURCE := $(SRC_DIR)/spec-sample.adoc +XTRA_ADOC_OPTS := ASCIIDOCTOR_PDF := asciidoctor-pdf ASCIIDOCTOR_HTML := asciidoctor OPTIONS := --trace \ @@ -34,6 +32,8 @@ OPTIONS := --trace \ -a revdate=${DATE} \ -a pdf-fontsdir=docs-resources/fonts \ -a pdf-theme=docs-resources/themes/riscv-pdf.yml \ + $(XTRA_ADOC_OPTS) \ + -D build \ --failure-level=ERROR REQUIRES := --require=asciidoctor-bibtex \ --require=asciidoctor-diagram \ @@ -55,14 +55,14 @@ build: build-container: @echo "Starting build inside Docker container..." - $(DOCKER_RUN) /bin/sh -c "$(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) --out-file=$(PDF_RESULT) $(HEADER_SOURCE)" - $(DOCKER_RUN) /bin/sh -c "$(ASCIIDOCTOR_HTML) $(OPTIONS) $(REQUIRES) --out-file=$(HTML_RESULT) $(HEADER_SOURCE)" + $(DOCKER_RUN) /bin/sh -c "$(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) $(HEADER_SOURCE)" + $(DOCKER_RUN) /bin/sh -c "$(ASCIIDOCTOR_HTML) $(OPTIONS) $(REQUIRES) $(HEADER_SOURCE)" @echo "Build completed successfully inside Docker container." build-no-container: @echo "Starting build..." - $(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) --out-file=$(PDF_RESULT) $(HEADER_SOURCE) - $(ASCIIDOCTOR_HTML) $(OPTIONS) $(REQUIRES) --out-file=$(HTML_RESULT) $(HEADER_SOURCE) + $(ASCIIDOCTOR_PDF) $(OPTIONS) $(REQUIRES) $(HEADER_SOURCE) + $(ASCIIDOCTOR_HTML) $(OPTIONS) $(REQUIRES) $(HEADER_SOURCE) @echo "Build completed successfully." clean: diff --git a/docs-resources b/docs-resources index 8abc9340..66f972d7 160000 --- a/docs-resources +++ b/docs-resources @@ -1 +1 @@ -Subproject commit 8abc93401a61e52c460888ff658518a56e37ee9c +Subproject commit 66f972d7dc961551a7815d2fceb82fbea7ce2c44 diff --git a/src/header.adoc b/src/spec-sample.adoc similarity index 100% rename from src/header.adoc rename to src/spec-sample.adoc From 36b88efbbcb99f7c4f9cf124d807dbb453543590 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Sat, 27 Jan 2024 12:16:44 -0300 Subject: [PATCH 73/75] Update GH Actions to Archieve the PDF from its new location Signed-off-by: Rafael Sene --- .github/workflows/build-pdf.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index 580c908a..a5581a7e 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -56,14 +56,14 @@ jobs: uses: actions/upload-artifact@v3 with: name: Build Artifacts - path: ${{ github.workspace }}/*.pdf + path: ${{ github.workspace }}/build/*.pdf retention-days: 30 # Create Release - name: Create Release uses: softprops/action-gh-release@v1 with: - files: ${{ github.workspace }}/*.pdf + files: ${{ github.workspace }}/build/*.pdf tag_name: v${{ github.event.inputs.version }} name: Release ${{ github.event.inputs.version }} draft: ${{ github.event.inputs.draft }} From 3507342e659b7f7087802240a2b1cd989f47ea62 Mon Sep 17 00:00:00 2001 From: Rafael Sene Date: Sat, 27 Jan 2024 07:28:32 -0800 Subject: [PATCH 74/75] Update Version of GH Action Modules --- .github/workflows/build-pdf.yml | 4 ++-- .github/workflows/pre-commit.yml | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/build-pdf.yml b/.github/workflows/build-pdf.yml index a5581a7e..c2b75d28 100644 --- a/.github/workflows/build-pdf.yml +++ b/.github/workflows/build-pdf.yml @@ -36,7 +36,7 @@ jobs: steps: # Step 1: Checkout the repository - name: Checkout repository - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: submodules: recursive @@ -53,7 +53,7 @@ jobs: # Step 4: Upload the built PDF files as a single artifact - name: Upload Build Artifacts - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: Build Artifacts path: ${{ github.workspace }}/build/*.pdf diff --git a/.github/workflows/pre-commit.yml b/.github/workflows/pre-commit.yml index 2126ca60..74b9ec35 100644 --- a/.github/workflows/pre-commit.yml +++ b/.github/workflows/pre-commit.yml @@ -10,6 +10,6 @@ jobs: pre-commit: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 - - uses: actions/setup-python@v3 + - uses: actions/checkout@v4 + - uses: actions/setup-python@v5 - uses: pre-commit/action@v3.0.0 From 182f02c967c07bb3954f6b1fb58e0b36c401afdb Mon Sep 17 00:00:00 2001 From: Alex Richardson Date: Mon, 29 Jan 2024 11:13:48 -0800 Subject: [PATCH 75/75] Add instructions on how to enable pre-commit Signed-off-by: Alex Richardson --- readme.adoc | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/readme.adoc b/readme.adoc index 68f2461a..559a49ea 100644 --- a/readme.adoc +++ b/readme.adoc @@ -63,3 +63,18 @@ To clean up the generated files, run: ```shell make clean ``` + + +== Enabling pre-commit checks locally +The repository has some basic commit checks set up with https://pre-commit.com/[pre-commit] that will be enforced by the GitHub CI. +To ensure these checks are also run in the local repository while making changes the following command can be run: +[source,shell] +---- +pip3 install pre-commit && pre-commit install +---- + +When enabling additional checks https://pre-commit.com/#plugins[by editing .pre-commit-config.yaml], it is recommended to run to newly added check on all files in the repository. This can be done with the following command: +[source,shell] +---- +pre-commit run --all-files +----