-
Notifications
You must be signed in to change notification settings - Fork 6
StyleGuide
The steps associated with the introduction of a new Sinara hardware project are outlined in the preamble to Hardware Status.
The Wiki is the main source of documentation for the Sinara ecosystem, explaining what the hardware can do and how it was designed to be used. It is mainly maintained by the community, and needs help keeping it up to date. If you add information to the wiki, you are expected to ensure and maintain its correctness. Incorrect or out-of-date information should be removed.
In the repository corresponding to each hardware design there is a wiki.
These pages should begin with an overview, containing:
- Brief description of what the board does and how it is intended to be used
- Photograph
- Link to detailed PDF documentation
- Link to schematic and other files on GitHub
- Link to any relevant Artiq pages (e.g. drivers)
This overview should be followed by a bullet-pointed specification, including things like:
- Current hardware version/status
- Suppliers and rough cost
- Power consumption
- Required minimum air flow (only for higher power EEMs)
- Size
- Number of EEM connectors
Finally, post links to relevant issues, measurement data/figures, advice, etc.
- v1.0rc1: first design/schematics review before the first prototype
- v1.0rc2, v1.0rc3, ...: subsequent design/schematics reviews
- v1.0: first prototype
- v1.1: first "production" run with minor tweaks
- v2.0: second (sometimes major) iteration of the design, potentially denoting only a prototype run.
- v2.1, v2.2 etc would be production runs including minor tweaks that require software changes.
- v2.2.1, v2.2.2 etc would be production runs including minor tweaks that do not require software changes
- Pre-release status means that the release is not ready for production
The git commit corresponding to each release should be tagged with a name like Kasli/v1.0rc1, allowing the source files for that release to be easily located.
The repository is for "source files" only, so please don't add "output files", such as schematic PDFs, gerbers, drill, XY, BOM, renderings, .cce files, etc. into the repository. These files should only be uploaded as part of a release and are uploaded to the releases that are generated from the tags. Design reviews etc are treated as "release candidate"/rc releases using the same system.
Each board repository has its own issue tracker. Meta issues such as those relating to inter-board design should be filed in the meta repository's issue tracker here.
Note that the Sayma issue tracker and project milestones are still located in the now mostly depreciated Sinara repository.
- Refer to the various standards.
- Use proper mounting hardware: supply and mount all parts (screws, handles, washers, angles, panels), handles of correct width, correct PCB angle brackets, sunk/pan head screws were mandated, use correct type and length of screws.
- Panels are 3U high and multiples of 4HP wide and designed and viewed in that orientation (panel retaining screws are at the bottom and at the top).
- Ensure that the panel extraction handle does not interfere with a cable/connector or LEDs and that it does not impede ergonomics of mounting/unmounting.
- The reference panel for all aspects of size, type, orientation, and position of font, label, logo is Urukul. Use the mono-space font from Altium PCBs. Use font size, line thickness as in the reference design.
- Material
- Panel material should be hard aluminum of 2.5 mm thickness.
- Panels coloring should be black ink on silver (plain transparent anodized Aluminum).
- Edges don't need to be anodized.
- Markings printed and cut on foil on anodized Aluminum are acceptable for prototyping rounds. Otherwise use properly milled and ink-filled processes.
- Make sure that borders around cutouts (e.g. 4xRJ45) are minimum width to provide mechanical stability.
- Connector Cutouts
- Enable the use of isolating washers for SMA connectors by sizing the cutout correctly.
- Use isolated BNC connectors where possible.
- Use sufficient length SMA connectors. Account for plastic washers on both sides of the panel. Verify panel position.
- Use through-hole angle-mounted SMA connectors.
- Ensure that the mounting hardware of the connectors (washers, screws) does not overlap with text on the panel.
- Supply all mounting hardware.
- Ensure that the mechanical stresses (during mounting or operation) are handled by the panel and not by the PCB.
- When assembling, tighten the screws on the angle brackets after tightening the screws on the connectors.
- Logo
- Put the ARTIQ logo on the front panel. Don't outline it. Use properly filled plotting. Use the same position and size as for the reference panel.
- Place the ARTIQ logo on the front panel at the same location in the top left independent of the width of the panel. Place it between the retaining screw of the panel and the sunk attachment screw of the PCB angle bracket.
- No logos (no company logos or names) other than the ARTIQ logo or the yet-to-be-designed Sinara logo.
- Board name, description
- Place a label with the board name (
Urukul
) and a minimal description (4x 1GS/s DDS
) right below the upper PCB angle bracket sunk mounting screw. Center it horizontally on the panel. Use proper English capitalization:Urukul 4x 1GS/s DDS
.
- Place a label with the board name (
- Channels
- Channels are numbered starting from zero.
- First channel should be at the top left, second channel top right, etc: Row-major with the origin at the top left.
- Call the channels
IOx
,INx
,OUTx
orRFx
wherex
is the channel number. - Place direction, status, fault, termination etc indicators as close to the channel connector as possible.
- Put a box around the channel and its indicators if the association is not immediately obvious.
- Put a box around channel groups (e.g. I/O direction for groups of four)
- Labels
- Label all indicators, connectors. Use
UPPER CASE
. - Place labels below the item they refer to where possible
- Place board status indicators at the bottom of the panel just above the handle.
- Label all indicators, connectors. Use
- Revision
- At the very bottom of the panel (just right of the bottom left panel retaining screw, independent of the width of the panel) place the revision number as
vX.Y
whereX
andY
are major and minor version numbers.
- At the very bottom of the panel (just right of the bottom left panel retaining screw, independent of the width of the panel) place the revision number as
Home
Team
Project Status
Purchasing Hardware
Style Guide
Kasli: FPGA Carrier
Kasli-SOC: SoC FPGA Carrier
DIO_BNC: Digital IO on BNCs
DIO_SMA: Digital IO on SMAs
DIO_MCX: Digital IO on MCXs
DIO_RJ45: LVDS IO on RJ45s
Zotino: 32ch DAC
Fastino: 32ch DAC
Zapper: 8ch Piezo Driver
HV_AMP_8CH: 8ch High Voltage Amp
Sampler: 8ch ADC
Mirny: Microwave Synthesiser
Almazny: 12GHz Mirny Mezzanine
Urukul: 4ch DDS
Phaser: 2ch AWG
Stabilizer: 2xADC+2xDAC Servo
Pounder: Stabilizer PDH Lock
Thermostat_EEM: 4ch Temp Controller
Kirdy: laser current driver
Clocker: Clock Buffer
AUX_PSU: 3-ch PSU
EEM_PWR_MOD_AC: Mains PSU
Humpback: SBC Carrier
VHDCI Carrier: VHDCI to EEM
Grabber: Camera Frame Grabber
Banker: Versatile 128x IO
uTCA Chassis
Metlino: uTCA MCH
Sayma: 8-channel smart AWG
RFSOC-AMC: RFSoC Platform
Clock generation mezzanines
Sayma analogue front ends
Misc uTCA hardware
Shuttler: 16ch fast DAC
TDC+ADC: 16ch
Booster: 8ch RF Power Amplifier
DiPho: Digital Photodiode
Thermostat: 2ch Temp Controller
Line Trigger
IDC-BNC
IDC-SMA
HD68 to IDC
Kasli BP Adapter
MCX_BNC_adapter
SATA to SFP
EDGE-SMA
EDGE-BNC
EDGE-SUBD9
EDGE-VHDCI
EDGE-VHDCI-buf
SFP: recommended components