The 96Boards website is built using the Jekyll static site generator. It uses the Linaro jumbo-jekyll-theme (which is used for all of the Linaro static websites). With the source for the 96Boards.org website available on GitHub in this repo, it makes it easy for community/technical contributors to submit content. The 96Boards documentation repo is synced into the _documentation directory during site builds that occur on our Atlassian Bamboo CI instance.
We will happily consider any contributions/feature requests that you may have. Please submit a PR with your changes and we will take a look. If you have contributor permissions you can also use the
Github Edit buttons available on all the website pages to help locate the file you wish to edit/raise an issue about.
Simple edits on GitHub
A simple edit to content can be made directly on the GitHub website. Find the page you would like to make changes to and click the "pencil" icon.
Once you've made your change you'll be able to add a change title and description. Make sure to select the "Create a new branch for this commit and start a pull request" option.
Then click "Propose file change" button. Maintainers of this website repo will then review and publish your change accordingly.
If you'd like a more detailed guide on making changes on GitHub then view the GitHub documentation here.
Using the git CLI
If you're familiar with using the git CLI then you can simply fork this repository and
git clone your fork to your machine. Then submit pull request on a
new branch based off of the
develop branch. This is due to the 96Boards.org website repo following the Git flow methodology. Push your changes to your fork and then create a pull request via the GitHub UI.
Building the Website
To make it easier to contribute to the content, Linaro provides a couple of Docker containers for building and checking the site. All you need is Docker installed on your computer and enough RAM and disc space.
To build the site:
cd <git repository directory> ./build-site.sh
To build the site and then serve it so that you can check your contribution appears:
cd <git repository directory> JEKYLL_ACTION="serve" ./build-site.sh
To check that your contribution doesn't include any broken links:
cd <built web site directory> ../check-links.sh
The built web site directory will be
staging.96boards.org unless you set
JEKYLLENV=production before building the site, in which case the directory will be
Below are a few guides that will help you edit/add new content to the website. If these guides are missing anything or you are struggling to get something working then feel free to open an issue here.
Pages are located in the _pages directory. Most of these pages are using the "flow" layout provided by the jumbo-jekyll-theme. This means that page content is predominantly described in the front matter of a Jekyll markdown file.
Below are basic guides on editing/adding pages but for a more in depth guide please view the theme documentation on adding pages here.
Editing a Page
Find the page you are looking to edit in the _pages directory. Modify the content that you would like to make changes to and then follow the instructions in the Contributions section. If you have any queries then feel free to post an issue in this repo.
Adding a Page
Locate the _pages directory and create a new markdown file in the format of
page_name.md. Jekyll pages consist of a front matter block and main content. We are using a custom layout for most of these pages but you can simply copy the content from another page and change the title and permalink accordingly. Then follow the instructions in the Contributions section. If you have any queries then feel free to post an issue in this repo.
Posts are located in the _posts directory of this repo and are organised in year / month directories. Posts are written in markdown and contain a front matter block which provides metadata for a given page.
Below are basic guides on editing/adding blog posts but for a more in-depth guide then please view the theme documentation on adding blog posts here.
Editing a Blog Post
Adding a Blog Post
The easiest way to add a blog post is to copy a previous post and edit/remove the front matter to your requirements. Make sure to change the date specified in the file name since posts are organised/displayed based on this data (e.g 2020-01-13-your-blog-title.md). Update the date, title, tags and other front matter fields as required. Add a high resolution image to the /assets/images/blog directory and then update the image field with the path to your image. Once ready, follow the contribution guide to create a pull request with your new blog post.
Editing a product
In order to edit a product you must first locate the product that you wish to edit. Products are located in the _product folder and are organised by the specification of the board. Each board has their own designated folder. Within the product folder is an images directory and a
README.md. Edit the product details accordingly in this
README.md and then follow the contribution guide.
Adding a product
Adding products is best to do from the git command line interface. If unfamiliar with this process then see the Using the git cli section under Contributions.
Step 1 - Duplicate similiar product folder
In order to add a product copy one of the products currently in the _product folder. Products are organised in the _product folder into the 96Boards specifications that are available (ce, ee, ie, and mezzanine). Please duplicate a product folder from one of these specification sub folders and modify accordingly.
Step 2 - Modify the front matter
We use the Jekyll front matter (YAML) values to help render your product on our Jekyll site. Please look at the other products README.md's for reference on how to structure the front matter (YAML).
Below we will step through each front matter(yaml) setting and explain what each value is used for when building the static pages.
--- # Your Product title - this is the definitive product title. title: Sophon Edge # The layout to be used - below is the layout that you should use unless # you have been directed otherwise by one of the 96Boards team. layout: product # This is the url that your product will be available at. # You should stick to the format /product/product-title # Please use dashes between words to keep the format consistent. permalink: /product/sophon-edge/ # The description of your product is used for the web pages description meta tag # and on page content where a description of your product is need. To maximize the # effectiveness of your description please choose a powerful starting sentence. description: |- The Bitmain Sophon™ Edge Developer Board is designed for bringing powerful Deep Learning capability to various types of applications through its quick prototype development. Sophon Edge Developer Board is powered by a BM1880, equipping tailored TPU support DNN/CNN/RNN/LSTM operations and models. This board is compatible with Linaro 96boards while also supporting modules for Arduino and Raspberry Pi. Developers can leverage off-the-shelf modules and develop cutting edge DL/ML applications, like facial detection and recognition, facial expression analysis, object detection and recognition, vehicle license plate recognition, voiceprint recognition, and more! # Keywords - these are used for meta keywords and can be used when finding boards with a # particular feature keywords: |- processing, power, Wi-Fi, Bluetooth connectivity, GPS, development, board, mid-tier, xilinx, fpga, processor, low cost, Product, Development, Platform, bitmain, sophon, edge, bm1880 # Product Short Description - this is used on the product index page to provide a brief # overview of your product. product_short_desc: "Bitmain Sophon™ Edge Developer Board is powered by the BM1880" # Product Specification - This is the 96Boards specification of your product and is used # by Jekyll when collecting products of a certain specification. # Please use either ee, ce, mezzanine or iot product_specification: ce # Display Product - this a boolean value that is used to determine if your product should be displayed. display_product: true # Product Images - These are the images of your board. The first image is the image that is featured on index pages/homepage. product_images: - images/sophon-front-sd.png - images/sophon-back-sd.png # Product Tab Menu - this is where you configure the tabs of the product tab bar. product_tab_menu: - tab_title: Getting Started tab_link: /documentation/consumer/sophon-edge/getting-started/ tab_position: 1 - tab_title: Documentation tab_link: /documentation/consumer/sophon-edge/ tab_position: 2 tab_position: 3 - tab_title: Support tab_link: https://discuss.96boards.org/c/products/sophon-edge/ tab_position: 4 tab_align_right: true # Product buy links - these links let you customize the buy links available for your product. product_buy_links: - # Title of your buy link link-title: Sophon Edge (US) # URL of your buy link link-url: https://sophon.ai/product/view/00020181017110652CiJsd2n6aOcHr4a/view.html # The short version of the site which the users are purchasing your board from. E.g Buy from Sophon.ai from: Sophon.ai # The type of your product e.g board, mezzanine, adapter etc type: board # The price of your board link-price: "$129.99" # The official currency short code prepended to the product price. link-price-currency: USD - link-title: Sophon Edge (CN) link-url: https://sophon.cn/product/view/00020181017110652CiJsd2n6aOcHr4a/view.html from: Sophon.ai type: board link-price: "¥899.00" link-price-currency: CNY # Product OS - This setting is used in the product layout to specify what operating systems are available for your board. product_os: - title: Linux link: /documentation/consumer/sophon-edge/downloads/ # Third part images - This setting is used in the product to show what third party images there are available for your board. If you have no third party images then please omit. product_third_party_images: - title: Coming Soon... link: # Product more info - This setting is used in the product to link to any other sources for more information about this board e.g vendor site, vendor documentation. product_more_info: - title: Sophon link: https://sophon.ai/ # Product accessories - shows the accessories that are available. product_accessories: - title: Power link: /product/power/ - title: Adapter link: /product/adapter/ - title: Debug link: /product/debug/ - title: Misc link: /product/misc/ # Product accessories - shows the mezzanine boards that can be used with your board. product_mezzanine: - title: Link Sprite Sensor Kit link: /product/linkspritesensorkit/ - title: UART Serial link: /product/uartserial/ - title: Sensors Mezzanine link: /product/sensors-mezzanine # Product kits - This allows you to add links to any kits that are available for your board. product_kits: - title: Coming Soon... product: true ---
Step 3 - Add product images
Please add product images to the images/ sub folder inside the folder for your board. Make sure to
optimize these images as best as possible to reduce the overhead on users when loading your product page. The first image that you add to the front matter will be the one that is used on the homepage/product index pages. Therefore you should ensure that this image is optimized whilst also being a relatively high resolution so that your product is displayed correctly.
Below you can see example of the product_images front matter value that you need to change to match your product images that you add to the images sub-folder.
--- ... product_images: - images/sophon-front-sd.png - images/sophon-back-sd.png ... ---
Please note: Due to the way product images are included, images should not include spaces in the filename otherwise they may not be rendered on the website as expected.
96boards projects are submitted by engineers that are developing hardware and software applications using 96Boards. You can view the current list of 96Boards projects here - 96Boards.org/projects. See below for details on editing or adding a project.
Editing a Project
If you already own a project then you can make changes to your 96boards-projects org repo. If you don't own the project but notice some things you would like to change then locate the relevant project in this org and then open an appropriate GitHub issue.
Adding a Project
96Boards.org/projects are maintained in the 96boards-projects GitHub organization. Clone the template repo. Submit a pull request with your changes. If it is approved, we'll create a new project repo for your project so that it can be added to the website.
Adding 96Boards News
# Add a link to the external news article. - link: https://www.cnx-software.com/2018/04/16/hikey-970-development-board-now-up-for-pre-order-for-299-99/ # Add the title of your news post. title: CNX Software # Tag news with a board's permalink for it to show on that boards page. board: /product/hikey970/ # Make sure to add the correct date. date: 2019-03-05 09:00:00+00:00 tags: hikey970, ce
If you add a
board with a valid product permalink url then your news will display on the product page as featured news (only the top 10 results will show - newest first).
If you'd like to add internal 96Boards news then add a News/Blog to 96Boards.org and tag with
96Boards. The top 10 most recent posts on Linaro.org that feature 96Boards will then display on /news/.
The 96Boards.org documentation is maintained in this repo so if you'd like to modify the documentation for a specific board then please head over to that repo and submit a pull request there.
If you come across any bugs/issues then please let us know by clicking the Submit an Issue button located at the bottom of every 96Boards.org web page. Alternatively you may open an issue here but please provide precise details on how to reproduce the bug/issue so that we can act on the issue as soon as possible.
Image file names
Due to the way product images are included, images should not include spaces in the filename otherwise it may not be rendered on the website as expected.