HOME
Shop
  • English
  • 简体中文
HOME
Shop
  • English
  • 简体中文
  • Product Series

    • FPGA+ARM

      • GM-3568JHF

        • 1. Introduction

          • About GM-3568JHF
        • 2. Quick Start

          • 00 Introduction
          • 01 Environment Setup
          • 02 Compilation Instructions
          • 03 Flashing Guide
          • 04 Debug Tools
          • 05 Software Update
          • 06 View Information
          • 07 Test Commands
          • 08 App Compilation
          • 09 Source Code Acquisition
        • 3. Peripherals and Interfaces

          • 01 USB
          • 02 Display and Touch
          • 03 Ethernet
          • 04 WIFI
          • 05 Bluetooth
          • 06 TF-Card
          • 07 Audio
          • 08 Serial Port
          • 09 CAN
          • 10 RTC
        • 4. Application Development

          • 01 UART read and write case
          • 02 Key detection case
          • 03 LED light flashing case
          • 04 MIPI screen detection case
          • 05 Read USB device information example
          • 06 FAN Detection Case
          • 07 FPGA FSPI Communication Case
          • 08 FPGA DMA read and write case
          • 09 GPS debugging case
          • 10 Ethernet Test Cases
          • 11 RS485 reading and writing examples
          • 12 FPGA IIC read and write examples
          • 13 PN532 NFC card reader case
          • 14 TF card reading and writing case
        • 5. QT Development

          • 01 ARM64 cross compiler environment construction
          • 02 QT program added automatic startup service
        • 6. RKNN_NPU Development

          • 01 RK3568 NPU Overview
          • 02 Development Environment Setup
          • Run Official YOLOv5 Example
          • Model Conversion Detailed Explanation
          • Run Custom Model on Board
        • 7. FPGA Development

          • ARM and FPGA Communication
          • /fpga-arm/GM-3568JHF/FPGA/ch02-FPGA-Development-Manual.html
        • 8. Others

          • 01 Modification of the root directory file system
          • 02 System auto-start service
        • 9. Download

          • Download Resources
    • ShimetaPi

      • M4-R1

        • 1. Introduction

          • 1.1 About M4-R1
        • 2. Quick Start

          • 2.1 OpenHarmony Overview
          • 2.2 Image Burning
          • 2.3 Development Environment Preparation
          • 2.4 Hello World Application
        • 3. Application Development

          • 3.1 Getting Started

            • 3.1.1 ArkTS Language Overview
            • 3.1.2 UI Components (Part 1)
            • 3.1.3 UI Components (Part 2)
            • 3.1.4 UI Components (Part 3)
          • 3.2 Advanced

            • 3.2.1 Getting Started Guide
            • 3.2.2 Usage of Third Party Libraries
            • 3.2.3 Deployment of the Application
            • 3.2.4 Factory Reset
            • 3.2.5 System Debug
            • 3.2.6 APP Stability Testing
            • 3.2.7 Application Testing
          • 3.3 Getting Docs

            • 3.3.1 Official Website Information
          • 3.4 Development Instructions

            • 3.4.1 Full SDK
            • 3.4.2 Introduction of Third Party Libraries
            • 3.4.3 Introduction of HDC Tool
            • 3.4.4 Restore Factory Mode
            • 3.4.5 Update System API
          • 3.5 First Application

            • 3.5.1 First ArkTS App
          • 3.6 Application Demo

            • 3.6.1 UART Tool
            • 3.6.2 Graphics Tablet
            • 3.6.3 Digital Clock
            • 3.6.4 WIFI Tool
        • 4. Device Development

          • 4.1 Ubuntu Environment Development

            • 4.1.1 Environment Setup
            • 4.1.2 Download Source Code
            • 4.1.3 Compile Source Code
          • 4.2 Using DevEco Device Tool

            • 4.2.1 Tool Introduction
            • 4.2.2 Environment Construction
            • 4.2.3 Import SDK
            • 4.2.4 Function Introduction
        • 5. Peripherals and Interfaces

          • 5.1 Raspberry Pi Interfaces
          • 5.2 GPIO Interface
          • 5.3 I2C Interface
          • 5.4 SPI Communication
          • 5.5 PWM Control
          • 5.6 Serial Port Communication
          • 5.7 TF Card Slot
          • 5.8 Display Screen
          • 5.9 Touch Screen
          • 5.10 Audio
          • 5.11 RTC
          • 5.12 Ethernet
          • 5.13 M.2
          • 5.14 MINI PCIE
          • 5.15 Camera
          • 5.16 WIFI BT
          • 5.17 HAT
        • 6. FAQ

          • 6.1 Download Link
      • M5-R1

        • 1. Introduction

          • M5-R1 Development Documentation
        • 2. Quick Start

          • OpenHarmony Overview
          • Image Burning
          • Development Environment Preparation
          • Hello World Application and Deployment
        • 3. Peripherals and Interfaces

          • 3.1 Raspberry Pi Interfaces
          • 3.2 GPIO Interface
          • 3.3 I2C Interface
          • 3.4 SPI Communication
          • 3.5 PWM Control
          • 3.6 Serial Port Communication
          • 3.7 TF Card Slot
          • 3.8 Display Screen
          • 3.9 Touch Screen
          • 3.10 Audio
          • 3.11 RTC
          • 3.12 Ethernet
          • 3.13 M.2
          • 3.14 MINI PCIE
          • 3.15 Camera
          • 3.16 WIFI BT
          • 3.17 HAT
        • 4. Application Development

          • 4.1 Getting Started

            • 4.1.1 ArkTS Language Overview
            • 4.1.2 UI Components (Part 1)
            • 4.1.3 UI Components (Part 2)
            • 4.1.4 UI Components (Part 3)
          • 4.2 Advanced

            • 4.2.1 Getting Started Guide
            • 4.2.2 Usage of Third Party Libraries
            • 4.2.3 Deployment of the Application
            • 4.2.4 Factory Reset
            • 4.2.5 System Debug
            • 4.2.6 APP Stability Testing
            • 4.2.7 Application Testing
        • 5. Device Development

          • 5.1 Environment Setup
          • 5.2 Download Source Code
          • 5.3 Compile Source Code
        • 6. Download

          • Data Download
    • OpenHarmony

      • SC-3568HA

        • 1. Introduction

          • 1.1 About SC-3568HA
        • 2. Quick Start

          • 2.1 OpenHarmony Overview
          • 2.2 Image Burning
          • 2.3 Development Environment Preparation
          • 2.4 Hello World Application
        • 3. Application Development

          • 3.1 ArkUI

            • 3.1.1 ArkTS Language Overview
            • 3.1.2 UI Components (Part 1)
            • 3.1.3 UI Components (Part 2)
            • 3.1.4 UI Components (Part 3)
          • 3.2 Advanced

            • 3.2.1 Getting Started Guide
            • 3.2.2 Usage of Third Party Libraries
            • 3.2.3 Deployment of the Application
            • 3.2.4 Factory Reset
            • 3.2.5 System Debug
            • 3.2.6 APP Stability Testing
            • 3.2.7 Application Testing
        • 4. Device Development

          • 4.1 Environment Setup
          • 4.2 Download Source Code
          • 4.3 Compile Source Code
        • 5. Peripherals and Interfaces

          • 5.1 Raspberry Pi Interfaces
          • 5.2 GPIO Interface
          • 5.3 I2C Interface
          • 5.4 SPI Communication
          • 5.5 PWM Control
          • 5.6 Serial Port Communication
          • 5.7 TF Card Slot
          • 5.8 Display Screen
          • 5.9 Touch Screen
          • 5.10 Audio
          • 5.11 RTC
          • 5.12 Ethernet
          • 5.13 M.2
          • 5.14 MINI PCIE
          • 5.15 Camera
          • 5.16 WIFI BT
          • 5.17 HAT
        • 6. FAQ

          • 6.1 Download Link
      • M-K1HSE

        • 1. Introduction

          • 1.1 Product Introduction
        • 2. Quick Start

          • 2.1 Debug Tool Installation
          • 2.2 Development Environment Setup
          • 2.3 Source Code Download
          • 2.4 Build Instructions
          • 2.5 Flashing Guide
          • 2.6 APT Update Sources
          • 2.7 View Board Info
          • 2.8 CLI LED and Key Test
          • 2.9 GCC Build Programs
        • 3. Application Development

          • 3.1 Basic Application Development

            • 3.1.1 Development Environment Preparation
            • 3.1.2 First Application HelloWorld
            • 3.1.3 Develop HAR Package
          • 3.2 Peripheral Application Cases

            • 3.2.1 UART Read/Write
            • 3.2.2 Key Demo
            • 3.2.3 LED Flash
        • 4. Peripherals and Interfaces

          • 4.1 Standard Peripherals

            • 4.1.1 USB
            • 4.1.2 Display and Touch
            • 4.1.3 Ethernet
            • 4.1.4 WIFI
            • 4.1.5 Bluetooth
            • 4.1.6 TF Card
            • 4.1.7 Audio
            • 4.1.8 Serial Port
            • 4.1.9 CAN
            • 4.1.10 RTC
          • 4.2 Interfaces

            • 4.2.1 Audio
            • 4.2.2 RS485
            • 4.2.3 Display
            • 4.2.4 Touch
        • 5. System Customization Development

          • 5.1 System Porting
          • 5.2 System Customization
          • 5.3 Driver Development
          • 5.4 System Debugging
          • 5.5 OTA Upgrade
        • 6. Download

          • 6.1 Download
    • EVS-Camera

      • CF-NRS1

        • 1. Introduction

          • 1.1 About CF-NRS1
          • 1.2 Event-Based Concepts
          • 1.3 Quick Start
          • 1.4 Resources
        • 2. Development

          • 2.1 Development Overview

            • 2.1.1 Shimetapi Hybrid Camera SDK Introduction
          • 2.2 Environment & API

            • 2.2.1 Environment Overview
            • 2.2.2 Development API Overview
          • 2.3 Linux Development

            • 2.3.1 Linux SDK Introduction
            • 2.3.2 Linux SDK API
            • 2.3.3 Linux Algorithm
            • 2.3.4 Linux Algorithm API
          • 2.4 Service & Web

            • 2.4.1 EVS Server
            • 2.4.2 Time Server
            • 2.4.3 EVS Web
        • 3. Download

          • 3.1 Download
        • 4. Common Problems

          • 4.1 Common Problems
      • CF-CRA2

        • 1. Introduction

          • 1.1 About CF-CRA2
        • 2. Download

          • 2.1 Download
      • EVS Module

        • 1. Related Concepts
        • 2. Hardware Preparation and Environment Configuration
        • 3. Example Program User Guide
        • Resources Download
    • AI-model

      • 1684XB-32T

        • 1. Introduction

          • AIBOX-1684XB-32 Introduction
        • 2. Quick Start

          • First time use
          • Network Configuration
          • Disk usage
          • Memory allocation
          • Fan Strategy
          • Firmware Upgrade
          • Cross-Compilation
          • Model Quantization
        • 3. Application Development

          • 3.1 Development Introduction

            • Sophgo SDK Development
            • SOPHON-DEMO Introduction
          • 3.2 Large Language Models

            • Deploying Llama3 Example
            • /ai-model/AIBOX-1684XB-32/application-development/LLM/Sophon_LLM_api_server-Development-AIBOX-1684XB-32.html
            • /ai-model/AIBOX-1684XB-32/application-development/LLM/MiniCPM-V-2_6-AIBOX-1684XB-32.html
            • /ai-model/AIBOX-1684XB-32/application-development/LLM/Qwen-2-5-VL-demo-Development-AIBOX-1684XB-32.html
            • /ai-model/AIBOX-1684XB-32/application-development/LLM/Qwen-3-chat-demo-Development-AIBOX-1684XB-32.html
            • /ai-model/AIBOX-1684XB-32/application-development/LLM/Qwen3-Qwen Agent-MCP.html
            • /ai-model/AIBOX-1684XB-32/application-development/LLM/Qwen3-langchain-AI Agent.html
          • 3.3 Deep Learning

            • ResNet (Image Classification)
            • LPRNet (License Plate Recognition)
            • SAM (Universal Image Segmentation Foundation Model)
            • YOLOv5 (Object Detection)
            • OpenPose (Human Keypoint Detection)
            • PP-OCR (Optical Character Recognition)
        • 4. Download

          • Resource Download
      • 1684X-416T

        • 1. Introduction

          • AIBOX-1684X-416 Introduction
        • 2. Demo Simple Operation Guide

          • Simple instructions for using shimeta smart monitoring demo
      • RDK-X5

        • 1. Introduction

          • RDK-X5 Hardware Introduction
        • 2. Quick Start

          • RDK-X5 Quick Start
        • 3. Application Development

          • 3.1 AI Online Model Development

            • AI Online Development - Experiment01
            • AI Online Development - Experiment02
            • AI Online Development - Experiment03
            • AI Online Development - Experiment04
            • AI Online Development - Experiment05
            • AI Online Development - Experiment06
          • 3.2 Large Language Models (Voice)

            • Voice LLM Application - Experiment01
            • Voice LLM Application - Experiment02
            • Voice LLM Application - Experiment03
            • Voice LLM Application - Experiment04
            • Voice LLM Application - Experiment05
            • Voice LLM Application - Experiment06
          • 3.3 40pin-IO Development

            • 40pin IO Development - Experiment01
            • 40pin IO Development - Experiment02
            • 40pin IO Development - Experiment03
            • 40pin IO Development - Experiment04
            • 40pin IO Development - Experiment05
            • 40pin IO Development - Experiment06
            • 40pin IO Development - Experiment07
          • 3.4 USB Module Development

            • USB Module Usage - Experiment01
            • USB Module Usage - Experiment02
          • 3.5 Machine Vision

            • Machine Vision Technology Development - Experiment01
            • Machine Vision Technology Development - Experiment02
            • Machine Vision Technology Development - Experiment03
            • Machine Vision Technology Development - Experiment04
          • 3.6 ROS2 Base Development

            • ROS2 Basic Development - Experiment01
            • ROS2 Basic Development - Experiment02
            • ROS2 Basic Development - Experiment03
            • ROS2 Basic Development - Experiment04
      • RDK-S100

        • 1. Introduction

          • 1.1 About RDK-S100
        • 2. Quick Start

          • 2.1 First Use
        • 3. Application Development

          • 3.1 AI Online Model Development

            • 3.1.1 Volcano Engine Doubao AI
            • 3.1.2 Image Analysis
            • 3.1.3 Multimodal Visual Analysis
            • 3.1.4 Multimodal Image Comparison
            • 3.1.5 Multimodal Document Analysis
            • 3.1.6 Camera AI Vision Analysis
          • 3.2 Large Language Models

            • 3.2.1 Speech Recognition
            • 3.2.2 Voice Conversation
            • 3.2.3 Multimodal Image Analysis
            • 3.2.4 Multimodal Image Comparison
            • 3.2.5 Multimodal Document Analysis
            • 3.2.6 Multimodal Vision Application
          • 3.3 40pin-IO Development

            • 3.3.1 GPIO Output LED Blink
            • 3.3.2 GPIO Input
            • 3.3.3 Key Control LED
            • 3.3.4 PWM Output
            • 3.3.5 Serial Output
            • 3.3.6 I2C Experiment
          • 3.4 USB Module Development

            • 3.4.1 USB Voice Module
            • 3.4.2 Sound Source Localization
          • 3.5 Machine Vision

            • 3.5.1 USB Camera
            • 3.5.2 Image Processing Basics
            • 3.5.3 Object Detection
            • 3.5.4 Image Segmentation
          • 3.6 ROS2 Base Development

            • 3.6.1 Environment Setup
            • 3.6.2 Create and Build Workspace
            • 3.6.3 ROS2 Topic Communication
            • 3.6.4 ROS2 Camera Application
    • Core-Board

      • C-3568BQ

        • 1. Introduction

          • C-3568BQ Introduction
      • C-3588LQ

        • 1. Introduction

          • C-3588LQ Introduction
      • GC-3568JBAF

        • 1. Introduction

          • GC-3568JBAF Introduction
      • C-K1BA

        • 1. Introduction

          • C-K1BA Introduction

15 M.2 SSD

1 M.2 Interface Introduction

The M.2 interface is a physical interface standard that can support multiple different communication protocols, including:

  • PCIe (Peripheral Component Interconnect Express)
  • SATA (Serial Advanced Technology Attachment)
  • USB (Universal Serial Bus)

Therefore, the speed and performance of the M.2 interface depend on the communication protocol and hardware implementation used. The M.2 interface can support PCIe 3.0, which is a high-speed data transmission protocol, usually used to connect graphics cards, solid-state drives (SSDs), and other devices requiring high bandwidth.

In modern computers, especially in the consumer market, the most common and important application of the M.2 interface is connecting solid-state drives (SSDs). And what we usually call "M.2 SSD", according to different protocols, is mainly divided into two categories:

  • NVMe protocol with higher performance (running on PCIe bus)
  • SATA protocol with performance comparable to traditional SATA hard drives

Simple understanding M.2 is the "slot and appearance", PCIe is the "highway", SATA is the "regular road", and NVMe is the "super traffic rules" running on the highway. Through this M.2 physical interface, we can choose which "road" and which "rules" the hard drive uses.

1.1 M.2 Slot Specifications

M.2 slots come in different physical sizes, including:

  • 2242
  • 2260
  • 2280
  • 22110

These numbers represent the length and width of the slot.

1.2 RK3568 PCIe Architecture

The RK3568 chip has:

  • 1 PCIe3.0 x2 Lane Dual Mode controller
  • 1 PCIe3.0 x1 Lane RC Mode controller
  • 1 PCIe3.0 x2 Lane PHY

Both the PCIe3.0 x2 Lane Dual Mode controller and the PCIe3.0 x1 Lane RC Mode controller are connected to the PCIe3.0 x2 Lane PHY, meaning two controllers connect to the same PHY.

The connection diagram is as follows:

RK3568 PCIe Architecture Diagram

2 M.2 Interface Board Card Location

M.2 Interface Location

The M.2 interface specifications of the development board:

  • PCIe type: PCIe Gen3 x 2 lane
  • Length specification: 2280
  • Protocol support: This interface can only be used with M2 NVMe protocol solid-state drives

3 M.2 SSD Usage - Command Line Method

3.1 Device Tree File Explanation

Tips

The file path below: out/kernel/src_tmp/linux-5.10/arch/arm64/boot/dts/rockchip Need to compile the source code first.

The pins used by PCIe are dedicated pins. You only need to enable the corresponding controller, and the corresponding pins will be set to the corresponding mode.

Tips

Although this part of DTS code is long, there are few places that users need to modify, mainly changing the status attribute to okay. Therefore, this chapter does not provide detailed analysis of the DTS, only showing key code and brief explanations!

First, let's look at the basic definition layer (rk3568.dtsi). Due to limited space, only the code for pcie30phy and pcie3x2 nodes is shown. Other nodes only have different register addresses and PHY usage.

pcie30phy: phy@fe8c0000 {
        compatible = "rockchip,rk3568-pcie3-phy";
        reg = <0x0 0xfe8c0000 0x0 0x20000>;
        #phy-cells = <0>;
        clocks = <&pmucru CLK_PCIE30PHY_REF_M>, <&pmucru CLK_PCIE30PHY_REF_N>,
                 <&cru PCLK_PCIE30PHY>;
        clock-names = "refclk_m", "refclk_n", "pclk";
        resets = <&cru SRST_PCIE30PHY>;
        reset-names = "phy";
        rockchip,phy-grf = <&pcie30_phy_grf>;
        status = "disabled";
};

pcie3x2: pcie@fe280000 {
        compatible = "rockchip,rk3568-pcie", "snps,dw-pcie";
        #address-cells = <3>;
        #size-cells = <2>;
        bus-range = <0x20 0x2f>;
        clocks = <&cru ACLK_PCIE30X2_MST>, <&cru ACLK_PCIE30X2_SLV>,
                 <&cru ACLK_PCIE30X2_DBI>, <&cru PCLK_PCIE30X2>,
                 <&cru CLK_PCIE30X2_AUX_NDFT>;
        clock-names = "aclk_mst", "aclk_slv",
                      "aclk_dbi", "pclk", "aux";
        device_type = "pci";
        interrupts = <GIC_SPI 165 IRQ_TYPE_LEVEL_HIGH>,
                     <GIC_SPI 164 IRQ_TYPE_LEVEL_HIGH>,
                     <GIC_SPI 163 IRQ_TYPE_LEVEL_HIGH>,
                     <GIC_SPI 162 IRQ_TYPE_LEVEL_HIGH>,
                     <GIC_SPI 161 IRQ_TYPE_LEVEL_HIGH>;
        interrupt-names = "sys", "pmc", "msg", "legacy", "err";
        #interrupt-cells = <1>;
        interrupt-map-mask = <0 0 0 7>;
        interrupt-map = <0 0 0 1 &pcie3x2_intc 0>,
                        <0 0 0 2 &pcie3x2_intc 1>,
                        <0 0 0 3 &pcie3x2_intc 2>,
                        <0 0 0 4 &pcie3x2_intc 3>;
        linux,pci-domain = <2>;
        num-ib-windows = <6>;
        num-ob-windows = <2>;
        max-link-speed = <3>;
        msi-map = <0x2000 &its 0x2000 0x1000>;
        num-lanes = <2>;
        phys = <&pcie30phy>;
        phy-names = "pcie-phy";
        power-domains = <&power RK3568_PD_PIPE>;
        ranges = <0x00000800 0x0 0x80000000 0x3 0x80000000 0x0 0x800000
                  0x81000000 0x0 0x80800000 0x3 0x80800000 0x0 0x100000
                  0x83000000 0x0 0x80900000 0x3 0x80900000 0x0 0x3f700000>;
        reg = <0x3 0xc0800000 0x0 0x400000>,
              <0x0 0xfe280000 0x0 0x10000>;
        reg-names = "pcie-dbi", "pcie-apb";
        resets = <&cru SRST_PCIE30X2_POWERUP>;
        reset-names = "pipe";
        /* rockchip,bifurcation; lane0 when using 1+1 */
        status = "disabled";

        pcie3x2_intc: legacy-interrupt-controller {
                interrupt-controller;
                #address-cells = <0>;
                #interrupt-cells = <1>;
                interrupt-parent = <&gic>;
                interrupts = <GIC_SPI 162 IRQ_TYPE_EDGE_RISING>;
        };
};

The above is the code for the pcie3x2 node. The three PCIE controllers provided by rk3568 are:

  • pcie2x1: PCIe 2.0 single-lane controller, register address 0xfe260000, uses combphy2_psq as PHY
  • pcie3x1: PCIe 3.0 single-lane controller, register address 0xfe270000, uses pcie30phy as PHY, supports bifurcation mode
  • pcie3x2: PCIe 3.0 dual-lane controller, register address 0xfe280000, uses pcie30phy as PHY, supports bifurcation mode

Each controller is configured with corresponding clock sources, interrupts, power domains, and reset signals. The default state is disabled.

Next is the pin configuration layer (rk3568-pinctrl.dtsi):

pcie20m0_pins: pcie20m0-pins {
	rockchip,pins =
		/* pcie20_clkreqnm0 */
		<0 RK_PA5 3 &pcfg_pull_none>,
		/* pcie20_perstnm0 */
		<0 RK_PB6 3 &pcfg_pull_none>,
		/* pcie20_wakenm0 */
		<0 RK_PB5 3 &pcfg_pull_none>;
};

pcie30x1m0_pins: pcie30x1m0-pins {
	rockchip,pins =
		/* pcie30x1_clkreqnm0 */
		<0 RK_PA4 3 &pcfg_pull_none>,
		/* pcie30x1_perstnm0 */
		<0 RK_PC3 3 &pcfg_pull_none>,
		/* pcie30x1_wakenm0 */
		<0 RK_PC2 3 &pcfg_pull_none>;
};

pcie30x2m0_pins: pcie30x2m0-pins {
	rockchip,pins =
		/* pcie30x2_clkreqnm0 */
		<0 RK_PA6 2 &pcfg_pull_none>,
		/* pcie30x2_perstnm0 */
		<0 RK_PC6 3 &pcfg_pull_none>,
		/* pcie30x2_wakenm0 */
		<0 RK_PC5 3 &pcfg_pull_none>;
};

Each PCIE controller provides multiple pin multiplexing modes (m0, m1, m2). Each configuration includes three key signals:

  • clkreqn: Clock request signal, used for power management
  • perstn: Reset signal, used for hardware reset control
  • waken: Wake signal, used to wake from low power state

Finally, let's look at the board-level configuration layer (rk3568-evb6-ddr3-v10.dtsi)

&pcie30phy {
	status = "okay";
};

&pcie2x1 {
	reset-gpios = <&gpio1 RK_PB2 GPIO_ACTIVE_HIGH>;
	vpcie3v3-supply = <&pcie20_3v3>;
	status = "okay";
};

&pcie3x1 {
	rockchip,bifurcation;
	reset-gpios = <&gpio3 RK_PA1 GPIO_ACTIVE_HIGH>;
	vpcie3v3-supply = <&pcie30_3v3>;
	status = "okay";
};

&pcie3x2 {
	rockchip,bifurcation;
	reset-gpios = <&gpio2 RK_PD6 GPIO_ACTIVE_HIGH>;
	vpcie3v3-supply = <&pcie30_3v3>;
	status = "okay";
};
  • Enable PHY: Set &pcie30phy node status = "okay" to enable PCIe 3.0 PHY
  • Configure reset GPIO: Specify reset control pin through reset-gpios attribute
  • Configure power supply: Associate 3.3V power regulator through vpcie3v3-supply attribute
  • Enable bifurcation mode: For PCIe 3.0 controller, can enable lane bifurcation function through rockchip,bifurcation attribute
  • Enable controller: Set status = "okay" to enable corresponding PCIE controller

Caution

Unlike TF cards, SSDs do not support hot-plugging! Please ensure the system is turned off before installing the solid-state drive to avoid data loss.

Users need to install the solid-state drive while the power is off, then start the system.

3.2 Common Commands for Testing M.2 SSD

After installing the drive, you can use commands just like with TF cards.

Use the command below to view the mount directory. After entering the mount directory, you can view files and operate through the command line.

df -h

3.3 Specific Demonstration of M.2 SSD Usage

View mount directory:

M.2 SSD Mount Directory

View SSD content:

M.2 SSD Content

Edit this page on GitHub
Last Updated:
Contributors: ZSL