Skip to content

Commit

Permalink
Deploying to gh-pages from @ 0bf2efb 🚀
Browse files Browse the repository at this point in the history
  • Loading branch information
github-merge-queue[bot] committed Dec 23, 2023
0 parents commit 604f75b
Show file tree
Hide file tree
Showing 94 changed files with 11,686 additions and 0 deletions.
Empty file added .nojekyll
Empty file.
1 change: 1 addition & 0 deletions CNAME
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
glasgow-embedded.org
21 changes: 21 additions & 0 deletions index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
<!DOCTYPE html>
<html lang="en-US">
<meta charset="utf-8">
<title>Redirecting&hellip;</title>
<link rel="canonical" href="latest/intro.html">
<script>location="latest/intro.html"</script>
<meta http-equiv="refresh" content="0; url=latest/intro.html">
<meta content="Glasgow Interface Explorer" name="og:title" />
<meta content="website" name="og:type" />
<meta content="https://glasgow-embedded.org/" name="og:url" />
<meta content="A highly capable and extremely flexible open source multitool for digital electronics" name="og:description" />
<meta content="https://www.crowdsupply.com/img/f9a9/glasgow-revc2_jpg_open-graph.jpg" name="og:image" />
<meta content="A Glasgow Interface Explorer PCB, without a case" name="og:image:alt" />
<meta content="Glasgow Interface Explorer" name="twitter:title" />
<meta content="summary_large_image" name="twitter:card" />
<meta content="A highly capable and extremely flexible open source multitool for digital electronics" name="twitter:description" />
<meta content="https://www.crowdsupply.com/img/f9a9/glasgow-revc2_jpg_project-main.jpg" name="twitter:image" />
<meta content="A Glasgow Interface Explorer PCB, without a case" name="twitter:image:alt" />
<h1>Redirecting&hellip;</h1>
<a href="latest/intro.html">Click here if you are not redirected.</a>
</html>
4 changes: 4 additions & 0 deletions latest/.buildinfo
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# Sphinx build info version 1
# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done.
config: b068581bd915ddce620275ee1653a51c
tags: 645f666f9bcd5a90fca523b33c5a78b7
Binary file added latest/.doctrees/build.doctree
Binary file not shown.
Binary file added latest/.doctrees/community.doctree
Binary file not shown.
Binary file added latest/.doctrees/contribute.doctree
Binary file not shown.
Binary file added latest/.doctrees/develop/applet.doctree
Binary file not shown.
Binary file added latest/.doctrees/develop/docs.doctree
Binary file not shown.
Binary file added latest/.doctrees/develop/firmware.doctree
Binary file not shown.
Binary file added latest/.doctrees/develop/hardware.doctree
Binary file not shown.
Binary file added latest/.doctrees/develop/index.doctree
Binary file not shown.
Binary file added latest/.doctrees/develop/software.doctree
Binary file not shown.
Binary file added latest/.doctrees/environment.pickle
Binary file not shown.
Binary file added latest/.doctrees/index.doctree
Binary file not shown.
Binary file added latest/.doctrees/install.doctree
Binary file not shown.
Binary file added latest/.doctrees/intro.doctree
Binary file not shown.
Binary file added latest/.doctrees/license.doctree
Binary file not shown.
Binary file added latest/.doctrees/purchase.doctree
Binary file not shown.
Binary file added latest/.doctrees/revisions.doctree
Binary file not shown.
Binary file added latest/.doctrees/use/basic.doctree
Binary file not shown.
Binary file added latest/.doctrees/use/index.doctree
Binary file not shown.
Binary file added latest/.doctrees/use/repl-script.doctree
Binary file not shown.
Binary file added latest/_images/glasgow-in-case.webp
Binary file not shown.
Binary file added latest/_images/glasgow-pcba.webp
Binary file not shown.
Binary file added latest/_images/revC-3drender-back.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added latest/_images/revC-3drender-front.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
76 changes: 76 additions & 0 deletions latest/_sources/build.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
.. _build:

Building hardware
=================

Pre-assembled Glasgow devices and cases are :ref:`available for purchase <purchasing>`. Since Glasgow is open hardware, you also have the option of building a device yourself.

.. attention::

If you manufacture your own devices from the design files in this repository, you must clearly distinguish the PCBs by modifying the silkscreen artwork such that the placeholder manufacturer name and/or logo are replaced with your own contact information.

If you use the PCBA design files and the BOM that are included in this repository without modifications (other than the modifications required above), the Glasgow project will provide the same degree of support for your device as it does for the CrowdSupply orders (except for repairs under warranty).

If you modify the design files (which the license allows you to do without restrictions), the Glasgow project will not in general provide support for such devices, and you must not call your modified devices "Glasgow". You must remove the name "Glasgow" from the PCB silkscreen artwork to ensure that the device is clearly identifiable as being modified from the original source files. You must run ``glasgow factory`` with the ``--using-modified-design-files=yes`` argument when preparing the device, which will appropriately mark the device and change the product name USB descriptor to not include "Glasgow".

If you are modifying the BOM to replace passive components with equivalent parts from a different vendor (such as in response to shortages), you may call your modified device "Glasgow". In addition, exceptions to the rule above can be made after discussing your case with Catherine "whitequark" or Piotr Esden-Tempski.


.. _assembling:

Assembling a device
-------------------

.. todo::

This section is not written yet.


.. _factory-flashing:

Factory flashing
----------------

"Factory flashing" refers to the process of assigning a brand new Glasgow board (that you probably just assembled) a serial number, as well as writing a few critical configuration options that will let the ``glasgow`` command use this device. Barring severe and unusual EEPROM corruption, this process is performed only once in the lifetime of a device.

To prepare for factory flashing, follow the :ref:`installation steps <initial-setup>`.

Any board that is being factory flashed must have a blank ``FX2_MEM`` EEPROM. If the ``FX2_MEM`` EEPROM is not completely erased (all bytes set to ``FF``), the factory flashing process may fail.

.. tab:: Linux

Configure your system to allow unprivileged access for anyone logged in to the physical terminal to any hardware that enumerates as the Cypress FX2 ROM bootloader:

.. code:: console
$ sudo cp config/70-cypress.rules /etc/udev/rules.d
$ sudo udevadm control --reload
$ sudo udevadm trigger -v -c add -s usb -a idVendor=04b4 -a idProduct=8613
Note that this rule will allow unprivileged access to any device based on the Cypress FX2 that has a blank EEPROM, and not just the Glasgow hardware specifically.

Plug in the newly assembled device. At this point, ``lsusb -d 04b4:8613`` should list one entry. Note the revision of the board you are factory flashing. If the board has revision ``C3``, run:

.. code:: console
$ glasgow factory --rev C3 --using-modified-design-files=<yes|no>
That's it! After running this command, the device will disconnect from USB and reconnect, and ``lsusb -d 20b7:9db1`` will list one entry.

.. tab:: Windows

The steps are similar to the steps for Linux, but you will need to use Zadig to bind the WinUSB driver to the device, since this will not happen automatically with a device that hasn't been flashed yet.

.. todo::

Write a full explanation here.

.. tab:: macOS

Plug in the newly assembled device. At this point, ``System Information.app`` should list the FX2 device with Vid ``04b4`` and Pid ``8613``. Note the revision of the board you are factory flashing. If the board has revision ``C3``, run:

.. code:: console
$ glasgow factory --rev C3 --using-modified-design-files=<yes|no>
That's it! After running this command, the device will disconnect from USB and reconnect, and after refreshing (⌘R) the information in ``System Information.app`` you should see a new entry with Vid ``20b7`` and Pid ``9db1``.
58 changes: 58 additions & 0 deletions latest/_sources/community.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
.. _community:

Community
=========

Glasgow Interface Explorer is a community-driven project that coordinates via `GitHub issues <issues_>`__ and real-time chat channels on multiple platforms:

* IRC channel `#glasgow at irc.libera.chat <irc_>`__ with `logs available <irclogs_>`__.
* Matrix channel `#glasgow-interface-explorer:matrix.org <matrix_>`__.
* Discord channel `#glasgow at 1BitSquared's Discord server <discord_>`__.

All of our chat channels are bridged together; regardless of which one you choose, your messages reach everyone on all of the platforms. Note that what you say will be logged in a public archive indexed by search engines.

.. _issues: https://github.com/GlasgowEmbedded/glasgow/issues
.. _irc: https://web.libera.chat/#glasgow
.. _irclogs: https://libera.irclog.whitequark.org/glasgow
.. _matrix: https://matrix.to/#/#glasgow-interface-explorer:matrix.org
.. _discord: https://1bitsquared.com/pages/chat


.. _fediverse:

Fediverse
---------

Many of the community members involved with the project have Fediverse pages; `@esden@chaos.social <https://chaos.social/@esden>`_ has been writing a lot about the process of mass manufacturing the hardware.

You, too, can join the conversation via the `#GlasgowInterfaceExplorer` hashtag. Please avoid using `#Glasgow`; we are not talking about the city. (Unless you live there, in which case both are appropriate!)


.. _meetings:

Weekly meetings
---------------

Every week we conduct an informal developer meeting on our chat channels, discussing the progress over the last week, outstanding issues, and any other matters that need attention. At the moment the meeting is scheduled **every Saturday at 22:00 UTC**, and the typical duration is one hour. Anyone is free to attend, and we publish our past `meeting minutes <minutes_>`__.

When conducting a meeting, we first discuss `nominated`_ issues, and then anything else that is brought up. Once discussed, the ``nominated`` tag is removed.

.. _minutes: https://github.com/GlasgowEmbedded/glasgow/tree/main/docs/meetings
.. _nominated: https://github.com/GlasgowEmbedded/glasgow/labels/nominated


.. _acknowledgements:

Acknowledgements
----------------

The Glasgow project has been built by its many `contributors <https://github.com/GlasgowEmbedded/Glasgow/graphs/contributors>`_, including some without whom the project would not have been possible:

* `@whitequark <https://github.com/whitequark>`_ originated the overall design, coordinates the project and implements most of gateware and software
* `@awygle <https://github.com/awygle>`_ designed the power/analog port circuitry and helped with layout of revB
* `@marcan <https://github.com/marcan>`_ improved almost every aspect of hardware for revC
* `@esden <https://github.com/esden>`_ is handling batch manufacturing
* `@smunaut <https://github.com/smunaut>`_ provided advice crucial for stability and performance of USB communication
* `@electroniceel <https://github.com/electroniceel>`_ improved the hardware for revC2, designed the test jig and is working on advanced protection circuitry
* `@Attie <https://github.com/attie>`_ improved and refactored many applets, hardware photos
* `@mwkmwkmwk <https://github.com/mwkmwkmwk>`_ does important maintenance work to keep the codebase in good shape
94 changes: 94 additions & 0 deletions latest/_sources/contribute.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
Contributing
============

The Glasgow project relies on many community members to contribute to the extensive scope covered by its hardware and software. The project has a strong commitment to stability: most importantly, every unit of hardware for which design files have been published in the ``main`` branch will be supported forever. This scope and support commitment is challenging and requires us to be careful in evaluating any contributions.

We expect every contributor to work with the maintainers to ensure longevity of their contribution. If your contribution is substantial, please discuss it via our :ref:`community channels <community>` before working on it to ensure that it fits the project goals and to coordinate a long-term support commitment, especially in the cases where exotic or expensive hardware is required to test the changes.


.. _bug-reports:

Contributing bug reports
------------------------

Bug reports are always welcome! If you are experiencing an issue with your device and you are not sure what kind of issue it is, :ref:`ask the community for assistance <community>`.

For a timely resolution of your issues involving the Glasgow software, include the following information when `reporting a bug on GitHub <issues_>`__:

* The version of the Glasgow software stack and environment components (as printed by ``glasgow --version``);

* The complete debug information produced by the command you are running (as printed by ``glasgow -vvv [command...]``).

If you believe there is an issue with the design of the Glasgow hardware or firmware, `open an issue on GitHub <issues_>`__. The Glasgow hardware and firmware have been extensively reviewed, evaluated, and tested, and it is relatively unlikely for you to experience a design issue.

If you believe that your device may be damaged or malfunctioning, and the device is unmodified from the design files published in this repository (bearing the "Glasgow" name on it), you may :ref:`ask the community for assistance <community>` before referring to the manufacturer of your device. If your device has been :ref:`modified from the original design files <build>` or does not bear the "Glasgow" name on it, you must request assistance from the manufacturer of your device. You may ask the community for assistance if you make it clear in your request that your device has been modified from the original design files, but the effort required to evaluate such modifications is scarcely available.

.. _issues: https://github.com/GlasgowEmbedded/glasgow/issues/new


.. _contributing-code:
.. _contributing-docs:

Contributing code or documentation
----------------------------------

You are expected to contribute code as a `pull request <pulls_>`__ containing a small number of self-contained commits with :ref:`descriptive messages <commit-messages>`, each of which individually captures a functional state of the working tree. If your pull request does not fit this description it will not be merged until it is cleaned up, but it is okay to have a draft pull request containing a large number of temporary commits while it is undergoing review or ongoing work.

As Git is a notoriously difficult version control system to use effectively, feel free to :ref:`ask the community for assistance <community>`. Often, your pull request will be edited by maintainers to ensure it fits the codebase well. In those cases the maintainer will usually rearrange the commits to fit our requirements.

The Glasgow project does not strictly adhere to any specific Python or C coding standards. If your code is structured and formatted similarly to existing code, it is good enough. You may be instructed to reformat your code to ensure that it fits the codebase well.

.. _pulls: https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests

.. _commit-messages:

Writing commit messages
#######################

When modifying Python code, the first line of a commit message should, if possible, start with the name of the module (not including the leading ``glasgow.``) that is being modified, such that ``git log --grep`` can be used to filter changes by scope:

.. code:: text
protocol.jtag_svf: accept and ignore whitespace in scan data.
The format is the same for Python code implementing applets:

.. code:: text
applet.interface.uart: make autobaud more reliable.
When modifying documentation, the first line of a commit message should start with ``manual:``, followed by the base name of the ``.rst`` file that is being modified:

.. code:: text
manual: intro: update the list of applets.
When modifying firmware, the first line of a commit message should start with ``firmware:``:

.. code:: text
firmware: fix an operator precedence issue.
If none of the cases above are a good fit, any descriptive message is sufficient.


.. _docs-archive:

Vendor documentation
####################

If you have used vendor documentation while writing the code you're contributing, you are required to:

* upload the documentation to the `Glasgow archive repository <archive_>`__; and

* reference the documentation at the top of the file in the following format:

.. code:: text
Ref: <insert vendor documentation title or, if impossible, any permanent-looking URL>
Document Number: <insert vendor document number; omit the field if one does not exist>
Accession: <insert Glasgow archive repository accession number>
If you cannot upload the documentation to the archive because it is under NDA and/or watermarked, :ref:`ask the community for assistance <community>`. Often, it is possible to collate enough information by using existing leaked documents or through parallel construction.

.. _archive: https://github.com/GlasgowEmbedded/archive
8 changes: 8 additions & 0 deletions latest/_sources/develop/applet.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
.. _applet:

Applets
=======

.. attention::

We do not yet have documentation for developing applets or a stable API, so for now every applet must be loaded from within the main ``glasgow`` package.
78 changes: 78 additions & 0 deletions latest/_sources/develop/docs.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
.. _docs:

Documentation
=============

The source files for this documentation manual is contained in the `GlasgowEmbedded/glasgow`_ repository under ``docs/manual/``. It is written in `reStructuredText`_ and published with `Sphinx`_, using `PDM`_ for package management.

To build the documentation locally, first `install PDM`_. Then, navigate to the working directory you have :ref:`installed <initial-setup>` the Glasgow software in, and run:

.. code:: console
$ cd docs/manual
$ pdm install
Once this step completes (which should always happen without errors), you are ready to edit the documentation. In a terminal, run:

.. code:: console
$ pdm run live
[sphinx-autobuild] > sphinx-build .../glasgow/docs/manual/src .../glasgow/docs/manual/out
Running Sphinx v7.1.2
loading pickled environment... done
building [mo]: targets for 0 po files that are out of date
writing output...
building [html]: targets for 0 source files that are out of date
updating environment: 0 added, 0 changed, 0 removed
reading sources...
looking for now-outdated files... none found
no targets are out of date.
build succeeded.
The HTML pages are in out.
[I 231002 04:16:58 server:335] Serving on http://127.0.0.1:8000
[I 231002 04:16:58 handlers:62] Start watching changes
[I 231002 04:16:58 handlers:64] Start detecting changes
This command starts a web server running on your local PC that allows you to quickly see any changes to the documentation you are making. Navigate to `the URL it prints <http://127.0.0.1:8000>`_, and open the page you would like to change. Whenever you edit the ``.rst`` file corresponding to the page, you should see the page automatically reload in the web browser, reflecting the new contents.

In some cases (primarily when you are updating the documentation index in the sidebar) the changes aren't picked up by the web server. In that case, remove the output directory to trigger a full rebuild.

The markup language we are using, reStructuredText, has an awkward syntax, and it is easy for new editors to introduce syntax changes. If this happens, the web server prints a warning message whenever the ``.rst`` file is saved. Watch out for these warnings---they can save a lot of time trying to understand why the markup does not render correctly.

To check that all of the external links in the documentation are valid, run the following command:

.. code:: console
$ pdm check
Running Sphinx v7.1.2
[part of the output elided]
( develop/docs: line 37) ok http://127.0.0.1:8000
( purchase: line 10) ok https://1bitsquared.de/products/glasgow
( purchase: line 9) ok https://1bitsquared.com/products/glasgow
( community: line 10) ok https://1bitsquared.com/pages/chat
( intro: line 69) ok https://asciinema.org/a/245309
( intro: line 69) ok https://asciinema.org/a/i9edqaUBVLLw7mRZCpdxe91Fu.svg
( install: line 106) ok https://brew.sh/
[... continued]
At the moment, some of the URLs fail despite being valid, so this command is not included in a continuous integration check.

.. _GlasgowEmbedded/glasgow: https://github.com/GlasgowEmbedded/glasgow
.. _reStructuredText: https://www.sphinx-doc.org/en/master/usage/restructuredtext/basics.html
.. _Sphinx: https://www.sphinx-doc.org/en/master/index.html
.. _PDM: https://pdm.fming.dev/latest/
.. _install PDM: https://pdm.fming.dev/latest/#installation


Style guide
-----------

When writing documentation, please try to follow our style:

* Only capitalise the first word of headings
* Insert two blank lines before headings
* Use ``.. note::`` and ``.. warning::`` sparingly, but where important details may otherwise be missed
* Use an em-dash (---), which can be written as ``---`` in restructured text
* Link to our official `GlasgowEmbedded <https://github.com/GlasgowEmbedded>`_ repositories where appropriate
Loading

0 comments on commit 604f75b

Please sign in to comment.