Table of Contents | ||
---|---|---|
|
Info |
---|
1. Overview
The following is a high-level overview of the problem being resolved by this project:
This project develops Linux ADC device driver in the Linux BSP for the i.MX RT10XX processor.
2. Requirements
2.1. Detailed Requirements
The following are the requirements for this project:
Provide a Linux demo project combining all the requirements in this project.
Rationale: Needed to let Customer integrate results of this project into target embedded application.
Implementation: Section: "Design: Demo project".
Test: Section: "Test Plan: Demo Project".
Develop Linux ADC device driver for the i.MX RT1050 ADC controller.
Rationale: Explicit Customer requirement.
Implementation: Section: "Design: Linux ADC Device Driver".
Test: Section: "Test Plan: Linux ADC Driver".
2.2. Detailed Non-Requirements
The following are the non-requirements for this project that may otherwise not be obvious:
None
3. Design
3.1. Detailed Design
3.1.1. Design: Demo project
This project will enable the required ADC functionality in the Linux configuration ("embedded project") called rootfs
, which resides in a projects/rootfs
directory, relative to the top of the Linux i.MX RT10XX installation.
3.1.2. Design: Linux ADC Device Driver
The clock driver for IMXRT10XX SoC will be updated to support the ADC clock gates.
There is the existing vf610_adc
driver in the Linux sources, which provides support for the ADC controller of the Vybrid and some other SoCs from the i.MX family. The i.MXRT10XX SoC has a similar ADC controller, however there are some low-level differences in the hardware interfaces (register offsets, etc). The driver will be updated to support the register set of the IMXRT10XX SoC. Support for the IMXRT10XX ADC will be enabled via the DTS
kernel file, using the new fls,imxrt10xx-adc
compatibility string.
3.2. Effect on Related Products
This project makes the following updates in the related products:
None
3.3. Changes to User Documentation
This project updates the following user documents:
None
3.4. Alternative Design
The following alternative design approaches were considered by this project but then discarded for some reason:
None
4. Test Plan
4.1. Secure Download Area
The downloadable materials developed by this project are available from a secure Web page on the Emcraft Systems web site. Specifically, proceed to the following URL to download the software materials:
...
Login: CONTACT EMCRAFT
Password: CONTACT EMCRAFT
4.2. Downloadable Files
The following files are available from the secure download area:
linux-adc.patch
- patch to the Linux kernel sources;projects-adc.patch
- patch to therootfs
project;rootfs.uImage
- prebuilt bootable Linux image;
4.3. Test Set-Up
4.3.1. Hardware Setup
The following hardware setup is required for the i.MX RT 10XX board:
the i.MX RT1050 EVKB or i.MX RT1060 EVKB board.
4.3.2. Software Setup
The following software setup is required:
Download the files listed in Section: "Downloadable Files" to the top of the Linux i.MX RT installation.
Install the BSP, as per the respective "Installing and activating cross development environment" document in the "Software" section on the Emcraft site.
From the top of the Linux installation, activate the Linux cross-compile environment by running:
Code Block $ . ACTIVATE.sh
From the top of the BSP installation, go to the Linux kernel tree and install the kernel patch, eg:
Code Block $ cd linux/ $ patch -p1 < ../../linux-adc.patch
From the top of the Linux installation, go to the
projects
sub-directory, and patch therootfs
project:Code Block $ cd projects/ $ patch -p1 < ../../projects-adc.patch
Build the
rootfs
project:Code Block $ cd projects/rootfs $ make
4.4. Detailed Test Plan
4.4.1. Test Plan: Demo Project
Perform the following step-wise test procedure:
Go to the
projects/rootfs
directory, build the loadable Linux image (rootfs.uImage
) and copy it to the TFTP directory on the host:Code Block $ cd projects/rootfs $ make
Boot the loadable Linux image (
rootfs.uImage
) to the target via TFTP and validate that it boots to the Linux shell:Code Block => run netboot Using ethernet@402D8000 device TFTP from server 192.168.1.73; our IP address is 192.168.1.105 Filename 'rootfs.uImage'. Load address: 0x80007fc0 Loading: ################################################################# ################################################################# ################################################################# ################################################################# ... / # uname Linux / #
4.4.2. Test Plan: Linux ADC Driver
Perform the following step-wise test procedure:
...