1 /*
2  * Copyright (c) 2024, Ambiq Micro Inc. <www.ambiq.com>
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #ifndef MSPI_AMBIQ_H_
8 #define MSPI_AMBIQ_H_
9 
10 #include <am_mcu_apollo.h>
11 
12 /* Hand-calculated minimum heap sizes needed to return a successful
13  * 1-byte allocation.  See details in lib/os/heap.[ch]
14  */
15 #define MSPI_AMBIQ_HEAP_MIN_SIZE (sizeof(void *) > 4 ? 56 : 44)
16 
17 #define MSPI_AMBIQ_HEAP_DEFINE(name, bytes)                                                       \
18 	char __attribute__((section(".mspi_buff")))                                               \
19 		kheap_##name[MAX(bytes, MSPI_AMBIQ_HEAP_MIN_SIZE)];                               \
20 	STRUCT_SECTION_ITERABLE(k_heap, name) = {                                                 \
21 		.heap =                                                                           \
22 			{                                                                         \
23 				.init_mem = kheap_##name,                                         \
24 				.init_bytes = MAX(bytes, MSPI_AMBIQ_HEAP_MIN_SIZE),               \
25 			},                                                                        \
26 	}
27 
28 struct mspi_ambiq_timing_cfg {
29 	uint8_t ui8WriteLatency;
30 	uint8_t ui8TurnAround;
31 	bool bTxNeg;
32 	bool bRxNeg;
33 	bool bRxCap;
34 	uint32_t ui32TxDQSDelay;
35 	uint32_t ui32RxDQSDelay;
36 	uint32_t ui32RXDQSDelayEXT;
37 };
38 
39 enum mspi_ambiq_timing_param {
40 	MSPI_AMBIQ_SET_WLC            = BIT(0),
41 	MSPI_AMBIQ_SET_RLC            = BIT(1),
42 	MSPI_AMBIQ_SET_TXNEG          = BIT(2),
43 	MSPI_AMBIQ_SET_RXNEG          = BIT(3),
44 	MSPI_AMBIQ_SET_RXCAP          = BIT(4),
45 	MSPI_AMBIQ_SET_TXDQSDLY       = BIT(5),
46 	MSPI_AMBIQ_SET_RXDQSDLY       = BIT(6),
47 	MSPI_AMBIQ_SET_RXDQSDLYEXT    = BIT(7),
48 };
49 
50 #define MSPI_PORT(n)    ((DT_REG_ADDR(DT_INST_BUS(n)) - MSPI0_BASE) /                             \
51 			(DT_REG_SIZE(DT_INST_BUS(n)) * 4))
52 
53 #define TIMING_CFG_GET_RX_DUMMY(cfg)                                                              \
54 	{                                                                                         \
55 		mspi_timing_cfg *timing = (mspi_timing_cfg *)cfg;                                 \
56 		timing->ui8TurnAround;                                                            \
57 	}
58 
59 #define TIMING_CFG_SET_RX_DUMMY(cfg, num)                                                         \
60 	{                                                                                         \
61 		mspi_timing_cfg *timing = (mspi_timing_cfg *)cfg;                                 \
62 		timing->ui8TurnAround = num;                                                      \
63 	}
64 
65 #endif
66