3#ifndef STM32H730_OSPI_H
4#define STM32H730_OSPI_H
13namespace peripherals {
464 static bool checkCommandInitStructParameters(
CommandInitStruct const& initStruct);
474 static uint32_t const FIFIO_BUFFER_SIZE = 32U;
476 static uint8_t s_txBuffer[FIFIO_BUFFER_SIZE];
477 static uint8_t s_bytesToTransmit;
478 static uint8_t s_transmitedBytes;
481 static uint8_t s_receivedBytes;
(OSPI) module register structure
DataLines
Enumeration for LineNumbers.
static void onTOInterrupt(OCTOSPIModuleAddress module)
Helper to call to handle time out interrupt.
ByteSize
Enumeration for ByteSize.
static void configureMemoryMappedMode(OCTOSPIModuleAddress module, CommandInitStruct const &cmdInitStruct, MemoryMapInitStructure const &mmInitStruct)
Configure the memory mapped mode.
static void configureAutoPollingModeBlocking(OCTOSPIModuleAddress module, CommandInitStruct &initStruct, AutoPollingInitStructure const &apInitStruct, uint32_t const timeout)
Configure the OSPI Automatic Polling Mode in blocking mode.
SampleShift
Enumeration for Sample shift.
static void cancel(OCTOSPIModuleAddress module)
Helper to cancel current transfer.
static void configureAutoPollingMode(OCTOSPIModuleAddress module, CommandInitStruct &initStruct, AutoPollingInitStructure const &apInitStruct, uint32_t const timeout)
Configure the OSPI Automatic Polling Mode with interrupt.
WrapSize
Enumeration for wrap size.
DualQuadMode
Enumeration for dual quad mode.
static bool isBusy(OCTOSPIModuleAddress module)
Determines if the OSPI interface is busy.
static void receiveBlocking(OCTOSPIModuleAddress module, uint8_t *pData, uint32_t const timeout)
Read an amount of data in blocking mode.
AutomaticStop
Enumeration for OSPI Autopolling Automatic Stop.
static void transmitBlocking(OCTOSPIModuleAddress module, uint8_t const *pData, uint32_t const timeout)
Transmit an amount of data in blocking mode.
static void onFTInterrupt(OCTOSPIModuleAddress module)
Helper to call to handle fifo threshold interrupt.
DDR_SIOO_Mode
Enumeration for OSPI DDR SIOOMode.
@ InstructionOnly1stCommand
@ InstructionEveryCommand
static void onSMInterrupt(OCTOSPIModuleAddress module)
Helper to call to handle status match interrupt.
static bool commandBlocking(OCTOSPIModuleAddress module, CommandInitStruct const &initStruct, uint32_t const timeout)
Sets the command configuration in blocking mode.
static void receive(OCTOSPIModuleAddress module, uint8_t *const pData)
Read an amount of data with interrupt.
static bool init(OCTOSPIModuleAddress module, InitStruct const &initStruct)
Initializes the OSPI peripheral according to the specified parameters in the OSPI_InitStruct.
static void readData(OCTOSPIModuleAddress module, CommandInitStruct const &cmdInitStruct, uint8_t *pData, uint32_t const maxlen)
Helper to read data.
FlashMemorySelection
Enumeration for Flash Memory Selection.
static void onTEInterrupt(OCTOSPIModuleAddress module)
Helper to call to handle transfer error interrupt.
Mode
Enumeration for Mode Selection.
@ Mode0
CLK must stay low while nCS is high (chip select released)
@ Mode3
CLK must stay high while nCS is high (chip select released)
static bool command(OCTOSPIModuleAddress module, CommandInitStruct const &initStruct, uint32_t const timeout)
Sets the command configuration in interrupt mode.
static void writeData(OCTOSPIModuleAddress module, CommandInitStruct const &cmdInitStruct, uint32_t const *pData, uint32_t const timeout)
Helper to write data.
FunctionalMode
Enumeration for OSPI Functional Mode.
MemoryType
Enumeration for Memory Type.
FreeRunningClock
Enumeration for free running clock.
TimeOutActivation
Enumeration for OSPI TimeOutActivation.
static void onTCInterrupt(OCTOSPIModuleAddress module)
Helper to call to handle transfer complete interrupt.
MatchMode
Enumeration for OSPI Autopolling MatchMode.
static void deInit()
Deinitializes the OSPI peripheral according to the specified parameters in the OSPI_InitStruct.
static void transmit(OCTOSPIModuleAddress module, uint8_t const *const pData)
Transmit an amount of data in interrupt mode.
ChipSelectHighTime
Enumeration for Chip select high time.
@ Cycle47
nCS stays high for at least 47 cycle between Flash memory commands
@ Cycle35
nCS stays high for at least 35 cycle between Flash memory commands
@ Cycle53
nCS stays high for at least 53 cycle between Flash memory commands
@ Cycle49
nCS stays high for at least 49 cycle between Flash memory commands
@ Cycle43
nCS stays high for at least 43 cycle between Flash memory commands
@ Cycle63
nCS stays high for at least 63 cycle between Flash memory commands
@ Cycle38
nCS stays high for at least 38 cycle between Flash memory commands
@ Cycle12
nCS stays high for at least 12 cycle between Flash memory commands
@ Cycle15
nCS stays high for at least 15 cycle between Flash memory commands
@ Cycle21
nCS stays high for at least 21 cycle between Flash memory commands
@ Cycle62
nCS stays high for at least 62 cycle between Flash memory commands
@ Cycle45
nCS stays high for at least 45 cycle between Flash memory commands
@ Cycle29
nCS stays high for at least 29 cycle between Flash memory commands
@ Cycle48
nCS stays high for at least 48 cycle between Flash memory commands
@ Cycle40
nCS stays high for at least 40 cycle between Flash memory commands
@ Cycle27
nCS stays high for at least 27 cycle between Flash memory commands
@ Cycle17
nCS stays high for at least 17 cycle between Flash memory commands
@ Cycle33
nCS stays high for at least 33 cycle between Flash memory commands
@ Cycle44
nCS stays high for at least 44 cycle between Flash memory commands
@ Cycle61
nCS stays high for at least 61 cycle between Flash memory commands
@ Cycle4
nCS stays high for at least 4 cycle between Flash memory commands
@ Cycle64
nCS stays high for at least 64 cycle between Flash memory commands
@ Cycle36
nCS stays high for at least 36 cycle between Flash memory commands
@ Cycle41
nCS stays high for at least 41 cycle between Flash memory commands
@ Cycle6
nCS stays high for at least 6 cycle between Flash memory commands
@ Cycle3
nCS stays high for at least 3 cycle between Flash memory commands
@ Cycle7
nCS stays high for at least 7 cycle between Flash memory commands
@ Cycle56
nCS stays high for at least 56 cycle between Flash memory commands
@ Cycle55
nCS stays high for at least 55 cycle between Flash memory commands
@ Cycle22
nCS stays high for at least 22 cycle between Flash memory commands
@ Cycle59
nCS stays high for at least 59 cycle between Flash memory commands
@ Cycle31
nCS stays high for at least 31 cycle between Flash memory commands
@ Cycle23
nCS stays high for at least 23 cycle between Flash memory commands
@ Cycle51
nCS stays high for at least 51 cycle between Flash memory commands
@ Cycle26
nCS stays high for at least 26 cycle between Flash memory commands
@ Cycle5
nCS stays high for at least 5 cycle between Flash memory commands
@ Cycle24
nCS stays high for at least 24 cycle between Flash memory commands
@ Cycle58
nCS stays high for at least 58 cycle between Flash memory commands
@ Cycle8
nCS stays high for at least 8 cycle between Flash memory commands
@ Cycle11
nCS stays high for at least 11 cycle between Flash memory commands
@ Cycle10
nCS stays high for at least 10 cycle between Flash memory commands
@ Cycle30
nCS stays high for at least 30 cycle between Flash memory commands
@ Cycle18
nCS stays high for at least 18 cycle between Flash memory commands
@ Cycle9
nCS stays high for at least 9 cycle between Flash memory commands
@ Cycle1
nCS stays high for at least 1 cycle between Flash memory commands
@ Cycle2
nCS stays high for at least 2 cycle between Flash memory commands
@ Cycle25
nCS stays high for at least 25 cycle between Flash memory commands
@ Cycle32
nCS stays high for at least 32 cycle between Flash memory commands
@ Cycle39
nCS stays high for at least 39 cycle between Flash memory commands
@ Cycle50
nCS stays high for at least 50 cycle between Flash memory commands
@ Cycle60
nCS stays high for at least 60 cycle between Flash memory commands
@ Cycle14
nCS stays high for at least 14 cycle between Flash memory commands
@ Cycle20
nCS stays high for at least 20 cycle between Flash memory commands
@ Cycle42
nCS stays high for at least 42 cycle between Flash memory commands
@ Cycle13
nCS stays high for at least 13 cycle between Flash memory commands
@ Cycle52
nCS stays high for at least 52 cycle between Flash memory commands
@ Cycle37
nCS stays high for at least 37 cycle between Flash memory commands
@ Cycle34
nCS stays high for at least 34 cycle between Flash memory commands
@ Cycle16
nCS stays high for at least 16 cycle between Flash memory commands
@ Cycle46
nCS stays high for at least 46 cycle between Flash memory commands
@ Cycle19
nCS stays high for at least 19 cycle between Flash memory commands
@ Cycle28
nCS stays high for at least 28 cycle between Flash memory commands
@ Cycle57
nCS stays high for at least 57 cycle between Flash memory commands
@ Cycle54
nCS stays high for at least 54 cycle between Flash memory commands
OCTOSPIModuleAddress
Enumeration of the available OCTOSPI modules on STM32H730.
This is a application specific file which is used to configure Imt.Base.Core.Math.
unsigned __int32 uint32_t
OSPI AutoPolling structure definition.
uint32_t interval
Specifies the number of clock cycles between two read during automatic polling phases....
AutomaticStop automaticStop
Specifies if automatic polling is stopped after a match.
MatchMode matchMode
Specifies the method used for determining a match.
uint32_t mask
Specifies the mask to be applied to the status bytes received. -> value between 0 and 0xFFFFFFFF.
uint32_t statusByteSize
Specifies the size of the status bytes received. -> Value between 1 and 4.
uint32_t match
Specifies the value to be compared with the masked status register to get a match....
OSPI Command structure definition.
uint32_t dummyCycle
Specifies the Number of Dummy Cycles. -> value between 0 and 31.
DataLines dataMode
Specifies the Data Mode (used for dummy cycles and data phases)
DataLines instructionMode
Specifies the Instruction Mode.
DataLines addressMode
Specifies the Address Mode.
ByteSize instructionSize
Specifies the Instruction size.
ByteSize addressSize
Specifies the Address Size.
uint32_t alternateBytes
Specifies the Alternate Bytes to be sent (Size from 1 to 4 bytes according AlternateBytesSize)
uint32_t address
Specifies the Address to be sent (Size from 1 to 4 bytes according AddressSize) -> value between 0x0 ...
ByteSize alternateByteSize
Specifies the Address Size.
uint32_t instruction
Specifies the Instruction to be sent -> value between 0x00 and 0xFF.
DataLines alternateByteMode
Specifies the Alternate Bytes Mode.
DDR_SIOO_Mode siooMode
Specifies the send instruction only once mode.
uint32_t numberData
Specifies the number of data to transfer. -> value between 0 and 0xFFFFFFFF (0 means undefined length...
OSPI Init structure definition.
WrapSize wrapSize
Specifies thewrap size of the memory.
Mode mode
specifies the mode
uint32_t clockPrescaler
Specifies the prescaler factor for generating clock based on the AHB clock. (0x00-0xFF)
uint32_t fifoThreshold
Specifies the threshold number of bytes in the FIFO (used only in indirect mode) (1-32)
SampleShift sampleShift
Specifies the Sample Shift. The data is sampled 1/2 clock cycle delay later to take in account extern...
FlashMemorySelection flashId
Specifies the Flash which will be used.
uint32_t flashSize
Number of bytes in Flash memory = 2^[FSIZE+1].
ChipSelectHighTime chipSelectHighTime
Specifies the Chip Select High Time.
FreeRunningClock freeRunningClock
Specifies if clock is free running.
MemoryType MemType
Specifies the memory type.
DualQuadMode dualQuad
Specifies if dual quad mode is enabled.
OSPI Memory Mapped mode structure definition.
TimeOutActivation timeOutActivation
Specifies if the time out counter is enabled to release the chip select.
uint32_t timeOutPeriod
Specifies the number of clock to wait when the FIFO is full before to release the chip select.