aboutsummaryrefslogtreecommitdiffstats
path: root/lib/pico-sdk/rp2350/hardware/structs/qmi.h
blob: bbcbd769856952db275c2b6e085a26692fa9c295 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
// THIS HEADER FILE IS AUTOMATICALLY GENERATED -- DO NOT EDIT

/**
 * Copyright (c) 2024 Raspberry Pi Ltd.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */
#ifndef _HARDWARE_STRUCTS_QMI_H
#define _HARDWARE_STRUCTS_QMI_H

/**
 * \file rp2350/qmi.h
 */

#include "hardware/address_mapped.h"
#include "hardware/regs/qmi.h"

// Reference to datasheet: https://datasheets.raspberrypi.com/rp2350/rp2350-datasheet.pdf#tab-registerlist_qmi
//
// The _REG_ macro is intended to help make the register navigable in your IDE (for example, using the "Go to Definition" feature)
// _REG_(x) will link to the corresponding register in hardware/regs/qmi.h.
//
// Bit-field descriptions are of the form:
// BITMASK [BITRANGE] FIELDNAME (RESETVALUE) DESCRIPTION

typedef struct {
    _REG_(QMI_M0_TIMING_OFFSET) // QMI_M0_TIMING
    // Timing configuration register for memory address window 0
    // 0xc0000000 [31:30] COOLDOWN     (0x1) Chip select cooldown period
    // 0x30000000 [29:28] PAGEBREAK    (0x0) When page break is enabled, chip select will...
    // 0x02000000 [25]    SELECT_SETUP (0) Add up to one additional system clock cycle of setup...
    // 0x01800000 [24:23] SELECT_HOLD  (0x0) Add up to three additional system clock cycles of active...
    // 0x007e0000 [22:17] MAX_SELECT   (0x00) Enforce a maximum assertion duration for this window's...
    // 0x0001f000 [16:12] MIN_DESELECT (0x00) After this window's chip select is deasserted, it...
    // 0x00000700 [10:8]  RXDELAY      (0x0) Delay the read data sample timing, in units of one half...
    // 0x000000ff [7:0]   CLKDIV       (0x04) Clock divisor
    io_rw_32 timing;
 
    _REG_(QMI_M0_RFMT_OFFSET) // QMI_M0_RFMT
    // Read transfer format configuration for memory address window 0.
    // 0x10000000 [28]    DTR          (0) Enable double transfer rate (DTR) for read commands:...
    // 0x00070000 [18:16] DUMMY_LEN    (0x0) Length of dummy phase between command suffix and data...
    // 0x0000c000 [15:14] SUFFIX_LEN   (0x0) Length of post-address command suffix, in units of 4 bits
    // 0x00001000 [12]    PREFIX_LEN   (1) Length of command prefix, in units of 8 bits
    // 0x00000300 [9:8]   DATA_WIDTH   (0x0) The width used for the data transfer
    // 0x000000c0 [7:6]   DUMMY_WIDTH  (0x0) The width used for the dummy phase, if any
    // 0x00000030 [5:4]   SUFFIX_WIDTH (0x0) The width used for the post-address command suffix, if any
    // 0x0000000c [3:2]   ADDR_WIDTH   (0x0) The transfer width used for the address
    // 0x00000003 [1:0]   PREFIX_WIDTH (0x0) The transfer width used for the command prefix, if any
    io_rw_32 rfmt;
 
    _REG_(QMI_M0_RCMD_OFFSET) // QMI_M0_RCMD
    // Command constants used for reads from memory address window 0.
    // 0x0000ff00 [15:8]  SUFFIX       (0xa0) The command suffix bits following the address, if...
    // 0x000000ff [7:0]   PREFIX       (0x03) The command prefix bits to prepend on each new transfer,...
    io_rw_32 rcmd;
 
    _REG_(QMI_M0_WFMT_OFFSET) // QMI_M0_WFMT
    // Write transfer format configuration for memory address window 0.
    // 0x10000000 [28]    DTR          (0) Enable double transfer rate (DTR) for write commands:...
    // 0x00070000 [18:16] DUMMY_LEN    (0x0) Length of dummy phase between command suffix and data...
    // 0x0000c000 [15:14] SUFFIX_LEN   (0x0) Length of post-address command suffix, in units of 4 bits
    // 0x00001000 [12]    PREFIX_LEN   (1) Length of command prefix, in units of 8 bits
    // 0x00000300 [9:8]   DATA_WIDTH   (0x0) The width used for the data transfer
    // 0x000000c0 [7:6]   DUMMY_WIDTH  (0x0) The width used for the dummy phase, if any
    // 0x00000030 [5:4]   SUFFIX_WIDTH (0x0) The width used for the post-address command suffix, if any
    // 0x0000000c [3:2]   ADDR_WIDTH   (0x0) The transfer width used for the address
    // 0x00000003 [1:0]   PREFIX_WIDTH (0x0) The transfer width used for the command prefix, if any
    io_rw_32 wfmt;
 
    _REG_(QMI_M0_WCMD_OFFSET) // QMI_M0_WCMD
    // Command constants used for writes to memory address window 0.
    // 0x0000ff00 [15:8]  SUFFIX       (0xa0) The command suffix bits following the address, if...
    // 0x000000ff [7:0]   PREFIX       (0x02) The command prefix bits to prepend on each new transfer,...
    io_rw_32 wcmd;
} qmi_mem_hw_t;

typedef struct {
    _REG_(QMI_DIRECT_CSR_OFFSET) // QMI_DIRECT_CSR
    // Control and status for direct serial mode
    // 0xc0000000 [31:30] RXDELAY      (0x0) Delay the read data sample timing, in units of one half...
    // 0x3fc00000 [29:22] CLKDIV       (0x06) Clock divisor for direct serial mode
    // 0x001c0000 [20:18] RXLEVEL      (0x0) Current level of DIRECT_RX FIFO
    // 0x00020000 [17]    RXFULL       (0) When 1, the DIRECT_RX FIFO is currently full
    // 0x00010000 [16]    RXEMPTY      (0) When 1, the DIRECT_RX FIFO is currently empty
    // 0x00007000 [14:12] TXLEVEL      (0x0) Current level of DIRECT_TX FIFO
    // 0x00000800 [11]    TXEMPTY      (0) When 1, the DIRECT_TX FIFO is currently empty
    // 0x00000400 [10]    TXFULL       (0) When 1, the DIRECT_TX FIFO is currently full
    // 0x00000080 [7]     AUTO_CS1N    (0) When 1, automatically assert the CS1n chip select line...
    // 0x00000040 [6]     AUTO_CS0N    (0) When 1, automatically assert the CS0n chip select line...
    // 0x00000008 [3]     ASSERT_CS1N  (0) When 1, assert (i
    // 0x00000004 [2]     ASSERT_CS0N  (0) When 1, assert (i
    // 0x00000002 [1]     BUSY         (0) Direct mode busy flag
    // 0x00000001 [0]     EN           (0) Enable direct mode
    io_rw_32 direct_csr;
 
    _REG_(QMI_DIRECT_TX_OFFSET) // QMI_DIRECT_TX
    // Transmit FIFO for direct mode
    // 0x00100000 [20]    NOPUSH       (0) Inhibit the RX FIFO push that would correspond to this...
    // 0x00080000 [19]    OE           (0) Output enable (active-high)
    // 0x00040000 [18]    DWIDTH       (0) Data width
    // 0x00030000 [17:16] IWIDTH       (0x0) Configure whether this FIFO record is transferred with...
    // 0x0000ffff [15:0]  DATA         (0x0000) Data pushed here will be clocked out falling edges of...
    io_wo_32 direct_tx;
 
    _REG_(QMI_DIRECT_RX_OFFSET) // QMI_DIRECT_RX
    // Receive FIFO for direct mode
    // 0x0000ffff [15:0]  DIRECT_RX    (0x0000) With each byte clocked out on the serial interface, one...
    io_ro_32 direct_rx;
 
    qmi_mem_hw_t m[2];
 
    // (Description copied from array index 0 register QMI_ATRANS0 applies similarly to other array indexes)
    _REG_(QMI_ATRANS0_OFFSET) // QMI_ATRANS0
    // Configure address translation for XIP virtual addresses 0x000000 through 0x3fffff (a 4 MiB window starting at +0 MiB).
    // 0x07ff0000 [26:16] SIZE         (0x400) Translation aperture size for this virtual address...
    // 0x00000fff [11:0]  BASE         (0x000) Physical address base for this virtual address range, in...
    io_rw_32 atrans[8];
} qmi_hw_t;

#define qmi_hw ((qmi_hw_t *)XIP_QMI_BASE)
static_assert(sizeof (qmi_hw_t) == 0x0054, "");

#endif // _HARDWARE_STRUCTS_QMI_H