The TQMa8MPxS which is located on the MB-SMARC-2 provides a powerful embedded module platform based on NXPs i.MX8 series. The BSP is based on the Yocto Project using TQ’s meta-tq hardware support layer, with build host setup instructions and BSP sources provided via GitHub.
Please see the meta-tq repository on GitHub for further instructions. A list of supported Yocto images and example configurations is available in the BSP repository GitHub.
TQ Systems provides comprehensive documentation on its embedded mini-module products to facilitate the evaluation and design phase with our products.
The following documents can be downloaded directly from our Website (no login required) for the desired product:
User Manual (Baseboard)
Detailed hardware descriptions, installation steps, jumper settings, connector layouts and troubleshooting tips.
User Manual (Module)
Electrical specifications, interface overviews, software setup guides and reference tables.
Datasheets
Absolute maximum ratings, timing diagrams and ordering information.
The archive includes:
TQ manages all Board Support Package (BSP) releases in the meta-tq GitHub repository using annotated Git tags. This ensures each release is traceable to an exact source snapshot and clearly documents which Yocto branch, platform (module) and software revision it covers.
Tag Format:
<YoctoBranch>.<ModuleIdentifier>.TQ.ARM.BSP.<RevisionNumber>
| Component | Description |
|---|---|
| YoctoBranch | Name of the Yocto Project release (e.g. kirkstone, scarthgap) |
| ModuleIdentifier | Target module name when present; omitted entirely for “scarthgap” tags |
| TQ.ARM.BSP | Literal marker for “Board Support Package – Software” |
| RevisionNumber | Four-digit, zero-padded incrementing counter (e.g. 0001, 0002, …) |
Examples:
kirkstone.TQMa64xxL.BSP.SW.0008
scarthgap.BSP.SW.0001 – here no module identifier is used
Supported Platforms Reference:
To see exactly which platforms (machines/boards) each BSP tag covers, open the meta-tq folder in that tag and view its README.md:
/tq-systems/meta-tq/tree/<git-tag>/meta-tq
Click on README.md there to find the full list of Yocto machine names, board variants, RAM options and support status.
in the top right corner.
Software Versions:
For the exact versions of U-Boot, Linux kernel and other components used in a BSP tag, view doc/README.SoftwareVersions.md in that tag.
tq-systems/meta-tq/blob/<git-tag>/meta-tq/doc/README.SoftwareVersions.md
| Feature | REV.010x |
|---|---|
| RAM configs | 1,2,4,8 GiB |
| CPU variants | i.MX8MPQ |
| Fuses / OCRAM | x |
| speed grade / temperature grade detection | x |
| UART (console on UART3, X20) | x |
| I2C | |
| system EEPROM parsing | x |
| PMIC | x |
| eMMC / SD | |
| Read | x |
| Write | x |
| Ethernet | |
| GBE0 (X11) | x |
| GBE1 (X10) | x |
| Bootdevices | |
| SD-Card on USDHC2 | x |
| eMMC on USDHC3 | x |
| QSPI-NOR on FlexSPI | x |
| Serial Downloader (X4) | x |
| USB | |
| USB 3.0 Host / Hub (X7) | x |
| USB 2.0 Host / Hub (X8) | x |
| USB 3.0 Micro / Hub, (X3, host only) | |
| USB DRD USB 2.0 (X4, peripheral only) | x |
| QSPI NOR | |
| Read with 1-4-4 SDR | x |
| PP / Erase with 1-1-4 SDR | x |
| Cortex M7 | |
| env settings for starting from TCM | |
| examples with UART3 as debug console |
TODO or not tested / supported
Only mainline kernel supported
| Feature | 6.12.y |
|---|---|
| RAM configs | 1,2,4,8 GiB |
| CPU variants | i.MX8MPQ |
| Fuses / OCRAM | x |
| speed grade / temperature grade detection | x |
| UART | |
| SER0 on UART1 (X39) | x |
| SER1 on UART3 (console, X20) | x |
| SER2 on UART2 (X25) | x |
| SER3 on UART4 (X40) | x |
| I2C | |
| EEPROMs | x |
| PMIC | x |
| RTC | x |
| Temperature Sensors | x |
| ENET | |
| GBE0 (X11) | x |
| GBE1 (X10) | x |
| USB | |
| USB 3.0 Host / Hub (X7) | x |
| USB 2.0 Host / Hub (X8) | x |
| USB 3.0 Micro / Hub, (X3, host only) | |
| USB DRD (USB 2.0 Cable Detect, VBUS, X4) | x |
| QSPI NOR | |
| Read with 1-4-4 SDR | x |
| PP / Erase with 1-4-4 SDR | x |
| Graphic / Multimedia | |
| GPU | x |
| VPU | x |
| Display | |
| LVDS (X46, X48) | x |
| Dual-Channel LVDS | x |
| HDMI (X6) | x |
| DisplayPort using MIPI-DSI Bridge (X5) | x |
| Audio | |
| HDMI | |
| Codec (Line IN / Line OUT / MIC) | x |
| PCIe | |
| wireless card at M.2 (X44) | x |
| CAN-FD | |
| CAN-FD (X29, X30) | x |
| Cortex M7 | |
| examples running from TCM | |
| use UART4 as debug console (see issues) | |
| MIPI CSI (see Issues section) | |
| Gray with Vision Components GmbH camera (Sensor OV9281) | |
| Raw Bayer with Vision Components GmbH camera (Sensor IMX327) | |
| NPU | |
| NPU |
Added
u-boot-imx-tq-2024.04:
rcw: update TQMLS1028A PCIe configuration
linux-ti-tq-6.12: update to latest ti-linux-6.12.y
linux-rt-tq-6.12: update to v6.12.74-rt16
imx-system-manager-tq: update to NXP version lf-6.18.2_1.0.0
This integrates all fixes and features from NXP release and port supported boards from TQ-Systems. Switch to use new branch TQM-lf-6.18.2
imx-oei-tq: update to NXP version lf-6.18.2_1.0.0
This integrates all fixes and features from NXP release and port supported boards from TQ-Systems. Switch to use new branch TQM-lf-6.18.2
linux-imx-tq-6.12:
linux-imx-tq-6.6:
This includes fixes from linux-stable up to tag v6.6.129
imx-system-manager-tq: update to NXP version lf-6.12.49_2.2.0
imx-oei-tq: update to NXP version lf-6.12.49_2.2.0
linux-ti-tq-6.12: enable rpmsg_ctrl kernel module
u-boot-imx-tq-2025.04:
Enable U-Boot environment handling from rootfs
Update to NXP downstream version lf-6.12.49_2.2.0
prepare for TQMa94xxLA
TQMa95xxLA/TQMa95xxSA: simplify and implrove board support code
Use board_phys_sdram_size generic implementation under arch/arm/mach-imx
and handle CPU variants with features disabled by fuses
TQMa95xxLA: FlexSPI boot support
imx-boot-tq:
prepare building for i.MX94
i.MX9[4,5]: do not build FlexSPI boot images for Octal SPI with DTR and DQS by default
Not all boards have Octal SPI assembled. Use generic but slower setup by default.
If needed this can be configured per board using modified QSPI_HEADER environment.
update to use upstream version lf-6.12.49-2.2.0
linux-imx-tq-6.12:
linux-tq-6.6:
linux-rt-tq-6.6-rt: update to v6.6.129-rt70
linux-tq-6.12:
linux-ti-tq-6.12:
linux-imx-tq-6.12: TQMa95xxLA: fix RTS / CTS pad configuration for LPUART5 / LPUART7.
UART did not work with activated hardware flow control.
imx-system-manager-tq:
TQMa95xxSA: fix DDR ranges.
The ranges shall reflect the assembled RAM size, not the addressable range of the DDR controller
u-boot-imx-tq-2025.04:
TQMa95xxLA: correct FlexSPI pin muxing
Muxing uses wrong pads. Thus FlexSPI could not be used.