2 ******************************************************************************
3 * @file stm32h7xx_hal_gfxmmu.c
4 * @author MCD Application Team
5 * @brief This file provides firmware functions to manage the following
6 * functionalities of the Graphic MMU (GFXMMU) peripheral:
7 * + Initialization and De-initialization.
9 * + Force flush and/or invalidate of cache.
10 * + Modify physical buffer addresses.
11 * + Modify cache and pre-fetch parameters.
14 ******************************************************************************
17 * Copyright (c) 2017 STMicroelectronics.
18 * All rights reserved.
20 * This software is licensed under terms that can be found in the LICENSE file
21 * in the root directory of this software component.
22 * If no LICENSE file comes with this software, it is provided AS-IS.
24 ******************************************************************************
26 ==============================================================================
27 ##### How to use this driver #####
28 ==============================================================================
30 *** Initialization ***
31 ======================
33 (#) As prerequisite, fill in the HAL_GFXMMU_MspInit() :
34 (++) Enable GFXMMU clock interface with __HAL_RCC_GFXMMU_CLK_ENABLE().
35 (++) If interrupts are used, enable and configure GFXMMU global
36 interrupt with HAL_NVIC_SetPriority() and HAL_NVIC_EnableIRQ().
37 (#) Configure the number of blocks per line, default value, physical
38 buffer addresses, cache and pre-fetch parameters and interrupts
39 using the HAL_GFXMMU_Init() function.
41 *** LUT configuration ***
42 =========================
44 (#) Use HAL_GFXMMU_DisableLutLines() to deactivate all LUT lines (or a
46 (#) Use HAL_GFXMMU_ConfigLut() to copy LUT from flash to look up RAM.
47 (#) Use HAL_GFXMMU_ConfigLutLine() to configure one line of LUT.
49 *** Force flush and/or invalidate of cache ***
50 ==============================================
52 (#) Use HAL_GFXMMU_ConfigForceCache() to flush and/or invalidate cache.
54 *** Modify physical buffer addresses ***
55 =======================================
57 (#) Use HAL_GFXMMU_ModifyBuffers() to modify physical buffer addresses.
59 *** Modify cache and pre-fetch parameters ***
60 =============================================
62 (#) Use HAL_GFXMMU_ModifyCachePrefetch() to modify cache and pre-fetch
65 *** Error management ***
66 ========================
68 (#) If interrupts are used, HAL_GFXMMU_IRQHandler() will be called when
69 an error occurs. This function will call HAL_GFXMMU_ErrorCallback().
70 Use HAL_GFXMMU_GetError() to get the error code.
72 *** De-initialization ***
73 =========================
75 (#) As prerequisite, fill in the HAL_GFXMMU_MspDeInit() :
76 (++) Disable GFXMMU clock interface with __HAL_RCC_GFXMMU_CLK_ENABLE().
77 (++) If interrupts has been used, disable GFXMMU global interrupt with
78 HAL_NVIC_DisableIRQ().
79 (#) De-initialize GFXMMU using the HAL_GFXMMU_DeInit() function.
81 *** Callback registration ***
82 =============================
85 The compilation define USE_HAL_GFXMMU_REGISTER_CALLBACKS when set to 1
86 allows the user to configure dynamically the driver callbacks.
87 Use functions HAL_GFXMMU_RegisterCallback() to register a user callback.
90 Function HAL_GFXMMU_RegisterCallback() allows to register following callbacks:
91 (+) ErrorCallback : GFXMMU error.
92 (+) MspInitCallback : GFXMMU MspInit.
93 (+) MspDeInitCallback : GFXMMU MspDeInit.
95 This function takes as parameters the HAL peripheral handle, the callback ID
96 and a pointer to the user callback function.
99 Use function HAL_GFXMMU_UnRegisterCallback() to reset a callback to the default
100 weak (surcharged) function.
101 HAL_GFXMMU_UnRegisterCallback() takes as parameters the HAL peripheral handle,
104 This function allows to reset following callbacks:
105 (+) ErrorCallback : GFXMMU error.
106 (+) MspInitCallback : GFXMMU MspInit.
107 (+) MspDeInitCallback : GFXMMU MspDeInit.
110 By default, after the HAL_GFXMMU_Init and if the state is HAL_GFXMMU_STATE_RESET
111 all callbacks are reset to the corresponding legacy weak (surcharged) functions:
112 examples HAL_GFXMMU_ErrorCallback().
113 Exception done for MspInit and MspDeInit callbacks that are respectively
114 reset to the legacy weak (surcharged) functions in the HAL_GFXMMU_Init
115 and HAL_GFXMMU_DeInit only when these callbacks are null (not registered beforehand).
116 If not, MspInit or MspDeInit are not null, the HAL_GFXMMU_Init and HAL_GFXMMU_DeInit
117 keep and use the user MspInit/MspDeInit callbacks (registered beforehand).
120 Callbacks can be registered/unregistered in READY state only.
121 Exception done for MspInit/MspDeInit callbacks that can be registered/unregistered
122 in READY or RESET state, thus registered (user) MspInit/DeInit callbacks can be used
123 during the Init/DeInit.
124 In that case first register the MspInit/MspDeInit user callbacks
125 using HAL_GFXMMU_RegisterCallback before calling HAL_GFXMMU_DeInit
126 or HAL_GFXMMU_Init function.
129 When the compilation define USE_HAL_GFXMMU_REGISTER_CALLBACKS is set to 0 or
130 not defined, the callback registering feature is not available
131 and weak (surcharged) callbacks are used.
134 ******************************************************************************
137 /* Includes ------------------------------------------------------------------*/
138 #include "stm32h7xx_hal.h"
140 /** @addtogroup STM32H7xx_HAL_Driver
143 #ifdef HAL_GFXMMU_MODULE_ENABLED
145 /** @defgroup GFXMMU GFXMMU
146 * @brief GFXMMU HAL driver module
150 /* Private typedef -----------------------------------------------------------*/
151 /* Private define ------------------------------------------------------------*/
152 #define GFXMMU_LUTXL_FVB_OFFSET 8U
153 #define GFXMMU_LUTXL_LVB_OFFSET 16U
154 #define GFXMMU_CR_ITS_MASK 0x1FU
155 /* Private macro -------------------------------------------------------------*/
156 /* Private variables ---------------------------------------------------------*/
157 /* Private function prototypes -----------------------------------------------*/
158 /* Exported functions --------------------------------------------------------*/
159 /** @defgroup GFXMMU_Exported_Functions GFXMMU Exported Functions
163 /** @defgroup GFXMMU_Exported_Functions_Group1 Initialization and de-initialization functions
164 * @brief Initialization and de-initialization functions
167 ==============================================================================
168 ##### Initialization and de-initialization functions #####
169 ==============================================================================
170 [..] This section provides functions allowing to:
171 (+) Initialize the GFXMMU.
172 (+) De-initialize the GFXMMU.
178 * @brief Initialize the GFXMMU according to the specified parameters in the
179 * GFXMMU_InitTypeDef structure and initialize the associated handle.
180 * @param hgfxmmu GFXMMU handle.
181 * @retval HAL status.
183 HAL_StatusTypeDef
HAL_GFXMMU_Init(GFXMMU_HandleTypeDef
*hgfxmmu
)
185 HAL_StatusTypeDef status
= HAL_OK
;
187 /* Check GFXMMU handle */
194 /* Check parameters */
195 assert_param(IS_GFXMMU_ALL_INSTANCE(hgfxmmu
->Instance
));
196 assert_param(IS_GFXMMU_BLOCKS_PER_LINE(hgfxmmu
->Init
.BlocksPerLine
));
197 assert_param(IS_GFXMMU_BUFFER_ADDRESS(hgfxmmu
->Init
.Buffers
.Buf0Address
));
198 assert_param(IS_GFXMMU_BUFFER_ADDRESS(hgfxmmu
->Init
.Buffers
.Buf1Address
));
199 assert_param(IS_GFXMMU_BUFFER_ADDRESS(hgfxmmu
->Init
.Buffers
.Buf2Address
));
200 assert_param(IS_GFXMMU_BUFFER_ADDRESS(hgfxmmu
->Init
.Buffers
.Buf3Address
));
201 assert_param(IS_FUNCTIONAL_STATE(hgfxmmu
->Init
.CachePrefetch
.Activation
));
202 assert_param(IS_FUNCTIONAL_STATE(hgfxmmu
->Init
.Interrupts
.Activation
));
204 #if (USE_HAL_GFXMMU_REGISTER_CALLBACKS == 1)
205 /* Reset callback pointers to the weak predefined callbacks */
206 hgfxmmu
->ErrorCallback
= HAL_GFXMMU_ErrorCallback
;
208 /* Call GFXMMU MSP init function */
209 if(hgfxmmu
->MspInitCallback
== NULL
)
211 hgfxmmu
->MspInitCallback
= HAL_GFXMMU_MspInit
;
213 hgfxmmu
->MspInitCallback(hgfxmmu
);
215 /* Call GFXMMU MSP init function */
216 HAL_GFXMMU_MspInit(hgfxmmu
);
219 /* Configure blocks per line, cache and interrupts parameters on GFXMMU_CR register */
220 hgfxmmu
->Instance
->CR
&= ~(GFXMMU_CR_B0OIE
| GFXMMU_CR_B1OIE
| GFXMMU_CR_B2OIE
| GFXMMU_CR_B3OIE
|
221 GFXMMU_CR_AMEIE
| GFXMMU_CR_192BM
| GFXMMU_CR_CE
| GFXMMU_CR_CL
|
222 GFXMMU_CR_CLB
| GFXMMU_CR_FC
| GFXMMU_CR_PD
| GFXMMU_CR_OC
|
224 hgfxmmu
->Instance
->CR
|= (hgfxmmu
->Init
.BlocksPerLine
);
225 if(hgfxmmu
->Init
.CachePrefetch
.Activation
== ENABLE
)
227 assert_param(IS_GFXMMU_CACHE_LOCK(hgfxmmu
->Init
.CachePrefetch
.CacheLock
));
228 assert_param(IS_GFXMMU_PREFETCH(hgfxmmu
->Init
.CachePrefetch
.Prefetch
));
229 assert_param(IS_GFXMMU_OUTTER_BUFFERABILITY(hgfxmmu
->Init
.CachePrefetch
.OutterBufferability
));
230 assert_param(IS_GFXMMU_OUTTER_CACHABILITY(hgfxmmu
->Init
.CachePrefetch
.OutterCachability
));
231 hgfxmmu
->Instance
->CR
|= (GFXMMU_CR_CE
|
232 hgfxmmu
->Init
.CachePrefetch
.CacheLock
|
233 hgfxmmu
->Init
.CachePrefetch
.Prefetch
|
234 hgfxmmu
->Init
.CachePrefetch
.OutterBufferability
|
235 hgfxmmu
->Init
.CachePrefetch
.OutterCachability
);
236 if(hgfxmmu
->Init
.CachePrefetch
.CacheLock
== GFXMMU_CACHE_LOCK_ENABLE
)
238 assert_param(IS_GFXMMU_CACHE_LOCK_BUFFER(hgfxmmu
->Init
.CachePrefetch
.CacheLockBuffer
));
239 assert_param(IS_GFXMMU_CACHE_FORCE(hgfxmmu
->Init
.CachePrefetch
.CacheForce
));
240 hgfxmmu
->Instance
->CR
|= (hgfxmmu
->Init
.CachePrefetch
.CacheLockBuffer
|
241 hgfxmmu
->Init
.CachePrefetch
.CacheForce
);
244 if(hgfxmmu
->Init
.Interrupts
.Activation
== ENABLE
)
246 assert_param(IS_GFXMMU_INTERRUPTS(hgfxmmu
->Init
.Interrupts
.UsedInterrupts
));
247 hgfxmmu
->Instance
->CR
|= hgfxmmu
->Init
.Interrupts
.UsedInterrupts
;
250 /* Configure default value on GFXMMU_DVR register */
251 hgfxmmu
->Instance
->DVR
= hgfxmmu
->Init
.DefaultValue
;
253 /* Configure physical buffer addresses on GFXMMU_BxCR registers */
254 hgfxmmu
->Instance
->B0CR
= hgfxmmu
->Init
.Buffers
.Buf0Address
;
255 hgfxmmu
->Instance
->B1CR
= hgfxmmu
->Init
.Buffers
.Buf1Address
;
256 hgfxmmu
->Instance
->B2CR
= hgfxmmu
->Init
.Buffers
.Buf2Address
;
257 hgfxmmu
->Instance
->B3CR
= hgfxmmu
->Init
.Buffers
.Buf3Address
;
259 /* Force invalidate cache if cache is enabled */
260 if(hgfxmmu
->Init
.CachePrefetch
.Activation
== ENABLE
)
262 hgfxmmu
->Instance
->CCR
|= GFXMMU_CACHE_FORCE_INVALIDATE
;
265 /* Reset GFXMMU error code */
266 hgfxmmu
->ErrorCode
= GFXMMU_ERROR_NONE
;
268 /* Set GFXMMU to ready state */
269 hgfxmmu
->State
= HAL_GFXMMU_STATE_READY
;
271 /* Return function status */
276 * @brief De-initialize the GFXMMU.
277 * @param hgfxmmu GFXMMU handle.
278 * @retval HAL status.
280 HAL_StatusTypeDef
HAL_GFXMMU_DeInit(GFXMMU_HandleTypeDef
*hgfxmmu
)
282 HAL_StatusTypeDef status
= HAL_OK
;
284 /* Check GFXMMU handle */
291 /* Check parameters */
292 assert_param(IS_GFXMMU_ALL_INSTANCE(hgfxmmu
->Instance
));
294 /* Disable all interrupts on GFXMMU_CR register */
295 hgfxmmu
->Instance
->CR
&= ~(GFXMMU_CR_B0OIE
| GFXMMU_CR_B1OIE
| GFXMMU_CR_B2OIE
| GFXMMU_CR_B3OIE
|
298 /* Call GFXMMU MSP de-init function */
299 #if (USE_HAL_GFXMMU_REGISTER_CALLBACKS == 1)
300 if(hgfxmmu
->MspDeInitCallback
== NULL
)
302 hgfxmmu
->MspDeInitCallback
= HAL_GFXMMU_MspDeInit
;
304 hgfxmmu
->MspDeInitCallback(hgfxmmu
);
306 HAL_GFXMMU_MspDeInit(hgfxmmu
);
309 /* Set GFXMMU to reset state */
310 hgfxmmu
->State
= HAL_GFXMMU_STATE_RESET
;
312 /* Return function status */
317 * @brief Initialize the GFXMMU MSP.
318 * @param hgfxmmu GFXMMU handle.
321 __weak
void HAL_GFXMMU_MspInit(GFXMMU_HandleTypeDef
*hgfxmmu
)
323 /* Prevent unused argument(s) compilation warning */
326 /* NOTE : This function should not be modified, when the function is needed,
327 the HAL_GFXMMU_MspInit could be implemented in the user file.
332 * @brief De-initialize the GFXMMU MSP.
333 * @param hgfxmmu GFXMMU handle.
336 __weak
void HAL_GFXMMU_MspDeInit(GFXMMU_HandleTypeDef
*hgfxmmu
)
338 /* Prevent unused argument(s) compilation warning */
341 /* NOTE : This function should not be modified, when the function is needed,
342 the HAL_GFXMMU_MspDeInit could be implemented in the user file.
346 #if (USE_HAL_GFXMMU_REGISTER_CALLBACKS == 1)
348 * @brief Register a user GFXMMU callback
349 * to be used instead of the weak predefined callback.
350 * @param hgfxmmu GFXMMU handle.
351 * @param CallbackID ID of the callback to be registered.
352 * This parameter can be one of the following values:
353 * @arg @ref HAL_GFXMMU_ERROR_CB_ID error callback ID.
354 * @arg @ref HAL_GFXMMU_MSPINIT_CB_ID MSP init callback ID.
355 * @arg @ref HAL_GFXMMU_MSPDEINIT_CB_ID MSP de-init callback ID.
356 * @param pCallback pointer to the callback function.
357 * @retval HAL status.
359 HAL_StatusTypeDef
HAL_GFXMMU_RegisterCallback(GFXMMU_HandleTypeDef
*hgfxmmu
,
360 HAL_GFXMMU_CallbackIDTypeDef CallbackID
,
361 pGFXMMU_CallbackTypeDef pCallback
)
363 HAL_StatusTypeDef status
= HAL_OK
;
365 if(pCallback
== NULL
)
367 /* update the error code */
368 hgfxmmu
->ErrorCode
|= GFXMMU_ERROR_INVALID_CALLBACK
;
369 /* update return status */
374 if(HAL_GFXMMU_STATE_READY
== hgfxmmu
->State
)
378 case HAL_GFXMMU_ERROR_CB_ID
:
379 hgfxmmu
->ErrorCallback
= pCallback
;
381 case HAL_GFXMMU_MSPINIT_CB_ID
:
382 hgfxmmu
->MspInitCallback
= pCallback
;
384 case HAL_GFXMMU_MSPDEINIT_CB_ID
:
385 hgfxmmu
->MspDeInitCallback
= pCallback
;
388 /* update the error code */
389 hgfxmmu
->ErrorCode
|= GFXMMU_ERROR_INVALID_CALLBACK
;
390 /* update return status */
395 else if(HAL_GFXMMU_STATE_RESET
== hgfxmmu
->State
)
399 case HAL_GFXMMU_MSPINIT_CB_ID
:
400 hgfxmmu
->MspInitCallback
= pCallback
;
402 case HAL_GFXMMU_MSPDEINIT_CB_ID
:
403 hgfxmmu
->MspDeInitCallback
= pCallback
;
406 /* update the error code */
407 hgfxmmu
->ErrorCode
|= GFXMMU_ERROR_INVALID_CALLBACK
;
408 /* update return status */
415 /* update the error code */
416 hgfxmmu
->ErrorCode
|= GFXMMU_ERROR_INVALID_CALLBACK
;
417 /* update return status */
425 * @brief Unregister a user GFXMMU callback.
426 * GFXMMU callback is redirected to the weak predefined callback.
427 * @param hgfxmmu GFXMMU handle.
428 * @param CallbackID ID of the callback to be unregistered.
429 * This parameter can be one of the following values:
430 * @arg @ref HAL_GFXMMU_ERROR_CB_ID error callback ID.
431 * @arg @ref HAL_GFXMMU_MSPINIT_CB_ID MSP init callback ID.
432 * @arg @ref HAL_GFXMMU_MSPDEINIT_CB_ID MSP de-init callback ID.
433 * @retval HAL status.
435 HAL_StatusTypeDef
HAL_GFXMMU_UnRegisterCallback(GFXMMU_HandleTypeDef
*hgfxmmu
,
436 HAL_GFXMMU_CallbackIDTypeDef CallbackID
)
438 HAL_StatusTypeDef status
= HAL_OK
;
440 if(HAL_GFXMMU_STATE_READY
== hgfxmmu
->State
)
444 case HAL_GFXMMU_ERROR_CB_ID
:
445 hgfxmmu
->ErrorCallback
= HAL_GFXMMU_ErrorCallback
;
447 case HAL_GFXMMU_MSPINIT_CB_ID
:
448 hgfxmmu
->MspInitCallback
= HAL_GFXMMU_MspInit
;
450 case HAL_GFXMMU_MSPDEINIT_CB_ID
:
451 hgfxmmu
->MspDeInitCallback
= HAL_GFXMMU_MspDeInit
;
454 /* update the error code */
455 hgfxmmu
->ErrorCode
|= GFXMMU_ERROR_INVALID_CALLBACK
;
456 /* update return status */
461 else if(HAL_GFXMMU_STATE_RESET
== hgfxmmu
->State
)
465 case HAL_GFXMMU_MSPINIT_CB_ID
:
466 hgfxmmu
->MspInitCallback
= HAL_GFXMMU_MspInit
;
468 case HAL_GFXMMU_MSPDEINIT_CB_ID
:
469 hgfxmmu
->MspDeInitCallback
= HAL_GFXMMU_MspDeInit
;
472 /* update the error code */
473 hgfxmmu
->ErrorCode
|= GFXMMU_ERROR_INVALID_CALLBACK
;
474 /* update return status */
481 /* update the error code */
482 hgfxmmu
->ErrorCode
|= GFXMMU_ERROR_INVALID_CALLBACK
;
483 /* update return status */
488 #endif /* USE_HAL_GFXMMU_REGISTER_CALLBACKS */
494 /** @defgroup GFXMMU_Exported_Functions_Group2 Operations functions
495 * @brief GFXMMU operation functions
498 ==============================================================================
499 ##### Operation functions #####
500 ==============================================================================
501 [..] This section provides functions allowing to:
503 (+) Force flush and/or invalidate of cache.
504 (+) Modify physical buffer addresses.
505 (+) Modify cache and pre-fetch parameters.
512 * @brief This function allows to copy LUT from flash to look up RAM.
513 * @param hgfxmmu GFXMMU handle.
514 * @param FirstLine First line enabled on LUT.
515 * This parameter must be a number between Min_Data = 0 and Max_Data = 1023.
516 * @param LinesNumber Number of lines enabled on LUT.
517 * This parameter must be a number between Min_Data = 1 and Max_Data = 1024.
518 * @param Address Start address of LUT in flash.
519 * @retval HAL status.
521 HAL_StatusTypeDef
HAL_GFXMMU_ConfigLut(const GFXMMU_HandleTypeDef
*hgfxmmu
,
523 uint32_t LinesNumber
,
526 HAL_StatusTypeDef status
= HAL_OK
;
528 /* Check parameters */
529 assert_param(IS_GFXMMU_ALL_INSTANCE(hgfxmmu
->Instance
));
530 assert_param(IS_GFXMMU_LUT_LINE(FirstLine
));
531 assert_param(IS_GFXMMU_LUT_LINES_NUMBER(LinesNumber
));
533 /* Check GFXMMU state and coherent parameters */
534 if((hgfxmmu
->State
!= HAL_GFXMMU_STATE_READY
) || ((FirstLine
+ LinesNumber
) > 1024U))
540 uint32_t current_address
, current_line
, lutxl_address
, lutxh_address
;
542 /* Initialize local variables */
543 current_address
= Address
;
545 lutxl_address
= (uint32_t) &(hgfxmmu
->Instance
->LUT
[2U * FirstLine
]);
546 lutxh_address
= (uint32_t) &(hgfxmmu
->Instance
->LUT
[(2U * FirstLine
) + 1U]);
548 /* Copy LUT from flash to look up RAM */
549 while(current_line
< LinesNumber
)
551 *((uint32_t *)lutxl_address
) = *((uint32_t *)current_address
);
552 current_address
+= 4U;
553 *((uint32_t *)lutxh_address
) = *((uint32_t *)current_address
);
554 current_address
+= 4U;
560 /* Return function status */
565 * @brief This function allows to disable a range of LUT lines.
566 * @param hgfxmmu GFXMMU handle.
567 * @param FirstLine First line to disable on LUT.
568 * This parameter must be a number between Min_Data = 0 and Max_Data = 1023.
569 * @param LinesNumber Number of lines to disable on LUT.
570 * This parameter must be a number between Min_Data = 1 and Max_Data = 1024.
571 * @retval HAL status.
573 HAL_StatusTypeDef
HAL_GFXMMU_DisableLutLines(const GFXMMU_HandleTypeDef
*hgfxmmu
,
575 uint32_t LinesNumber
)
577 HAL_StatusTypeDef status
= HAL_OK
;
579 /* Check parameters */
580 assert_param(IS_GFXMMU_ALL_INSTANCE(hgfxmmu
->Instance
));
581 assert_param(IS_GFXMMU_LUT_LINE(FirstLine
));
582 assert_param(IS_GFXMMU_LUT_LINES_NUMBER(LinesNumber
));
584 /* Check GFXMMU state and coherent parameters */
585 if((hgfxmmu
->State
!= HAL_GFXMMU_STATE_READY
) || ((FirstLine
+ LinesNumber
) > 1024U))
591 uint32_t current_line
, lutxl_address
, lutxh_address
;
593 /* Initialize local variables */
595 lutxl_address
= (uint32_t) &(hgfxmmu
->Instance
->LUT
[2U * FirstLine
]);
596 lutxh_address
= (uint32_t) &(hgfxmmu
->Instance
->LUT
[(2U * FirstLine
) + 1U]);
598 /* Disable LUT lines */
599 while(current_line
< LinesNumber
)
601 *((uint32_t *)lutxl_address
) = 0U;
602 *((uint32_t *)lutxh_address
) = 0U;
608 /* Return function status */
613 * @brief This function allows to configure one line of LUT.
614 * @param hgfxmmu GFXMMU handle.
615 * @param lutLine LUT line parameters.
616 * @retval HAL status.
618 HAL_StatusTypeDef
HAL_GFXMMU_ConfigLutLine(const GFXMMU_HandleTypeDef
*hgfxmmu
, GFXMMU_LutLineTypeDef
*lutLine
)
620 HAL_StatusTypeDef status
= HAL_OK
;
622 /* Check parameters */
623 assert_param(IS_GFXMMU_ALL_INSTANCE(hgfxmmu
->Instance
));
624 assert_param(IS_GFXMMU_LUT_LINE(lutLine
->LineNumber
));
625 assert_param(IS_GFXMMU_LUT_LINE_STATUS(lutLine
->LineStatus
));
626 assert_param(IS_GFXMMU_LUT_BLOCK(lutLine
->FirstVisibleBlock
));
627 assert_param(IS_GFXMMU_LUT_BLOCK(lutLine
->LastVisibleBlock
));
628 assert_param(IS_GFXMMU_LUT_LINE_OFFSET(lutLine
->LineOffset
));
630 /* Check GFXMMU state */
631 if(hgfxmmu
->State
!= HAL_GFXMMU_STATE_READY
)
637 uint32_t lutxl_address
, lutxh_address
;
639 /* Initialize local variables */
640 lutxl_address
= (uint32_t) &(hgfxmmu
->Instance
->LUT
[2U * lutLine
->LineNumber
]);
641 lutxh_address
= (uint32_t) &(hgfxmmu
->Instance
->LUT
[(2U * lutLine
->LineNumber
) + 1U]);
643 /* Configure LUT line */
644 if(lutLine
->LineStatus
== GFXMMU_LUT_LINE_ENABLE
)
646 /* Enable and configure LUT line */
647 *((uint32_t *)lutxl_address
) = (lutLine
->LineStatus
|
648 (lutLine
->FirstVisibleBlock
<< GFXMMU_LUTXL_FVB_OFFSET
) |
649 (lutLine
->LastVisibleBlock
<< GFXMMU_LUTXL_LVB_OFFSET
));
650 *((uint32_t *)lutxh_address
) = (uint32_t) lutLine
->LineOffset
;
654 /* Disable LUT line */
655 *((uint32_t *)lutxl_address
) = 0U;
656 *((uint32_t *)lutxh_address
) = 0U;
659 /* Return function status */
664 * @brief This function allows to force flush and/or invalidate of cache.
665 * @param hgfxmmu GFXMMU handle.
666 * @param ForceParam Force cache parameter.
667 * This parameter can be a values combination of @ref GFXMMU_CacheForceParam.
668 * @retval HAL status.
670 HAL_StatusTypeDef
HAL_GFXMMU_ConfigForceCache(GFXMMU_HandleTypeDef
*hgfxmmu
, uint32_t ForceParam
)
672 HAL_StatusTypeDef status
= HAL_OK
;
674 /* Check parameters */
675 assert_param(IS_GFXMMU_ALL_INSTANCE(hgfxmmu
->Instance
));
676 assert_param(IS_GFXMMU_CACHE_FORCE_ACTION(ForceParam
));
678 /* Check GFXMMU state and cache status */
679 if(((hgfxmmu
->Instance
->CR
& GFXMMU_CR_CE
) != GFXMMU_CR_CE
) || (hgfxmmu
->State
!= HAL_GFXMMU_STATE_READY
))
685 /* Force flush and/or invalidate cache on GFXMMU_CCR register */
686 hgfxmmu
->Instance
->CCR
|= ForceParam
;
688 /* Return function status */
693 * @brief This function allows to modify physical buffer addresses.
694 * @param hgfxmmu GFXMMU handle.
695 * @param Buffers Buffers parameters.
696 * @retval HAL status.
698 HAL_StatusTypeDef
HAL_GFXMMU_ModifyBuffers(GFXMMU_HandleTypeDef
*hgfxmmu
, GFXMMU_BuffersTypeDef
*Buffers
)
700 HAL_StatusTypeDef status
= HAL_OK
;
702 /* Check parameters */
703 assert_param(IS_GFXMMU_ALL_INSTANCE(hgfxmmu
->Instance
));
704 assert_param(IS_GFXMMU_BUFFER_ADDRESS(Buffers
->Buf0Address
));
705 assert_param(IS_GFXMMU_BUFFER_ADDRESS(Buffers
->Buf1Address
));
706 assert_param(IS_GFXMMU_BUFFER_ADDRESS(Buffers
->Buf2Address
));
707 assert_param(IS_GFXMMU_BUFFER_ADDRESS(Buffers
->Buf3Address
));
709 /* Check GFXMMU state */
710 if(hgfxmmu
->State
!= HAL_GFXMMU_STATE_READY
)
716 /* Modify physical buffer addresses on GFXMMU_BxCR registers */
717 hgfxmmu
->Instance
->B0CR
= Buffers
->Buf0Address
;
718 hgfxmmu
->Instance
->B1CR
= Buffers
->Buf1Address
;
719 hgfxmmu
->Instance
->B2CR
= Buffers
->Buf2Address
;
720 hgfxmmu
->Instance
->B3CR
= Buffers
->Buf3Address
;
722 /* Return function status */
727 * @brief This function allows to modify cache and pre-fetch parameters.
728 * @param hgfxmmu GFXMMU handle.
729 * @param CachePrefetch Cache and pre-fetch parameters.
730 * @retval HAL status.
732 HAL_StatusTypeDef
HAL_GFXMMU_ModifyCachePrefetch(GFXMMU_HandleTypeDef
*hgfxmmu
,
733 GFXMMU_CachePrefetchTypeDef
*CachePrefetch
)
735 HAL_StatusTypeDef status
= HAL_OK
;
736 assert_param(IS_FUNCTIONAL_STATE(CachePrefetch
->Activation
));
738 /* Check parameters */
739 assert_param(IS_GFXMMU_ALL_INSTANCE(hgfxmmu
->Instance
));
741 /* Check GFXMMU state */
742 if(hgfxmmu
->State
!= HAL_GFXMMU_STATE_READY
)
748 /* Modify cache and pre-fetch parameters on GFXMMU_CR register */
749 hgfxmmu
->Instance
->CR
&= ~(GFXMMU_CR_CE
| GFXMMU_CR_CL
| GFXMMU_CR_CLB
| GFXMMU_CR_FC
|
750 GFXMMU_CR_PD
| GFXMMU_CR_OC
| GFXMMU_CR_OB
);
751 if(CachePrefetch
->Activation
== ENABLE
)
753 assert_param(IS_GFXMMU_CACHE_LOCK(CachePrefetch
->CacheLock
));
754 assert_param(IS_GFXMMU_PREFETCH(CachePrefetch
->Prefetch
));
755 assert_param(IS_GFXMMU_OUTTER_BUFFERABILITY(CachePrefetch
->OutterBufferability
));
756 assert_param(IS_GFXMMU_OUTTER_CACHABILITY(CachePrefetch
->OutterCachability
));
757 hgfxmmu
->Instance
->CR
|= (GFXMMU_CR_CE
|
758 CachePrefetch
->CacheLock
|
759 CachePrefetch
->Prefetch
|
760 CachePrefetch
->OutterBufferability
|
761 CachePrefetch
->OutterCachability
);
762 if(CachePrefetch
->CacheLock
== GFXMMU_CACHE_LOCK_ENABLE
)
764 assert_param(IS_GFXMMU_CACHE_LOCK_BUFFER(CachePrefetch
->CacheLockBuffer
));
765 assert_param(IS_GFXMMU_CACHE_FORCE(CachePrefetch
->CacheForce
));
766 hgfxmmu
->Instance
->CR
|= (CachePrefetch
->CacheLockBuffer
|
767 CachePrefetch
->CacheForce
);
771 /* Return function status */
776 * @brief This function handles the GFXMMU interrupts.
777 * @param hgfxmmu GFXMMU handle.
780 void HAL_GFXMMU_IRQHandler(GFXMMU_HandleTypeDef
*hgfxmmu
)
782 uint32_t flags
, interrupts
, error
;
784 /* Read current flags and interrupts and determine which error occurs */
785 flags
= hgfxmmu
->Instance
->SR
;
786 interrupts
= (hgfxmmu
->Instance
->CR
& GFXMMU_CR_ITS_MASK
);
787 error
= (flags
& interrupts
);
791 /* Clear flags on GFXMMU_FCR register */
792 hgfxmmu
->Instance
->FCR
= error
;
794 /* Update GFXMMU error code */
795 hgfxmmu
->ErrorCode
|= error
;
797 /* Call GFXMMU error callback */
798 #if (USE_HAL_GFXMMU_REGISTER_CALLBACKS == 1)
799 hgfxmmu
->ErrorCallback(hgfxmmu
);
801 HAL_GFXMMU_ErrorCallback(hgfxmmu
);
807 * @brief Error callback.
808 * @param hgfxmmu GFXMMU handle.
811 __weak
void HAL_GFXMMU_ErrorCallback(GFXMMU_HandleTypeDef
*hgfxmmu
)
813 /* Prevent unused argument(s) compilation warning */
816 /* NOTE : This function should not be modified, when the callback is needed,
817 the HAL_GFXMMU_ErrorCallback could be implemented in the user file.
825 /** @defgroup GFXMMU_Exported_Functions_Group3 State functions
826 * @brief GFXMMU state functions
829 ==============================================================================
830 ##### State functions #####
831 ==============================================================================
832 [..] This section provides functions allowing to:
833 (+) Get GFXMMU handle state.
834 (+) Get GFXMMU error code.
840 * @brief This function allows to get the current GFXMMU handle state.
841 * @param hgfxmmu GFXMMU handle.
842 * @retval GFXMMU state.
844 HAL_GFXMMU_StateTypeDef
HAL_GFXMMU_GetState(const GFXMMU_HandleTypeDef
*hgfxmmu
)
846 /* Return GFXMMU handle state */
847 return hgfxmmu
->State
;
851 * @brief This function allows to get the current GFXMMU error code.
852 * @param hgfxmmu GFXMMU handle.
853 * @retval GFXMMU error code.
855 uint32_t HAL_GFXMMU_GetError(GFXMMU_HandleTypeDef
*hgfxmmu
)
859 /* Enter in critical section */
862 /* Store and reset GFXMMU error code */
863 error_code
= hgfxmmu
->ErrorCode
;
864 hgfxmmu
->ErrorCode
= GFXMMU_ERROR_NONE
;
866 /* Exit from critical section */
869 /* Return GFXMMU error code */
880 /* End of exported functions -------------------------------------------------*/
881 /* Private functions ---------------------------------------------------------*/
882 /* End of private functions --------------------------------------------------*/
888 #endif /* HAL_GFXMMU_MODULE_ENABLED */