mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-08-16 09:27:01 +02:00
All identifiers, regardless of use, that start with two underscores are reserved. This means they can't be used in header guards. The style that this project is now to use the full name of the file in capital letters followed by 'H'. For example, for a file called "uart_example.h", the header guard is UART_EXAMPLE_H. The exceptions are files that are imported from other projects: - CryptoCell driver - dt-bindings folders - zlib headers Change-Id: I50561bf6c88b491ec440d0c8385c74650f3c106e Signed-off-by: Antonio Nino Diaz <antonio.ninodiaz@arm.com>
33 lines
904 B
C
33 lines
904 B
C
/*
|
|
* Copyright (c) 2016, ARM Limited and Contributors. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#ifndef RK3399_MCU_H
|
|
#define RK3399_MCU_H
|
|
|
|
#include <addressmap.h>
|
|
|
|
typedef unsigned int uint32_t;
|
|
|
|
#define mmio_read_32(c) ({unsigned int __v = \
|
|
(*(volatile unsigned int *)(c)); __v; })
|
|
#define mmio_write_32(c, v) ((*(volatile unsigned int *)(c)) = (v))
|
|
|
|
#define mmio_clrbits_32(addr, clear) \
|
|
mmio_write_32(addr, (mmio_read_32(addr) & ~(clear)))
|
|
#define mmio_setbits_32(addr, set) \
|
|
mmio_write_32(addr, (mmio_read_32(addr)) | (set))
|
|
#define mmio_clrsetbits_32(addr, clear, set) \
|
|
mmio_write_32(addr, (mmio_read_32(addr) & ~(clear)) | (set))
|
|
|
|
#define MIN(a, b) ((a) < (b) ? (a) : (b))
|
|
#define MAX(a, b) ((a) > (b) ? (a) : (b))
|
|
|
|
void stopwatch_init_usecs_expire(unsigned int usecs);
|
|
int stopwatch_expired(void);
|
|
void stopwatch_reset(void);
|
|
|
|
#endif /* RK3399_MCU_H */
|