Zephyr API Documentation 4.3.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
sys-io-common.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2021 Synopsys.
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#ifndef ZEPHYR_INCLUDE_ARCH_ARC_SYS_IO_COMMON_H_
8#define ZEPHYR_INCLUDE_ARCH_ARC_SYS_IO_COMMON_H_
9
10#ifndef _ASMLANGUAGE
11
12#include <zephyr/toolchain.h>
13#include <zephyr/sys/sys_io.h>
15
16#include <zephyr/types.h>
17#include <stddef.h>
18
19#ifdef __cplusplus
20extern "C" {
21#endif
22
24{
25 uint8_t value;
26
27 compiler_barrier();
28 value = *(volatile uint8_t *)addr;
29 compiler_barrier();
30
31 return value;
32}
33
35{
36 compiler_barrier();
37 *(volatile uint8_t *)addr = data;
38 compiler_barrier();
39}
40
42{
43 uint16_t value;
44
45 compiler_barrier();
46 value = *(volatile uint16_t *)addr;
47 compiler_barrier();
48
49 return value;
50}
51
53{
54 compiler_barrier();
55 *(volatile uint16_t *)addr = data;
56 compiler_barrier();
57}
58
60{
61 uint32_t value;
62
63 compiler_barrier();
64 value = *(volatile uint32_t *)addr;
65 compiler_barrier();
66
67 return value;
68}
69
71{
72 compiler_barrier();
73 *(volatile uint32_t *)addr = data;
74 compiler_barrier();
75}
76
77#ifdef CONFIG_64BIT
79{
80 uint64_t value;
81
82 compiler_barrier();
83 value = *(volatile uint64_t *)addr;
84 compiler_barrier();
85
86 return value;
87}
88
89static ALWAYS_INLINE void sys_write64(uint64_t data, mem_addr_t addr)
90{
91 compiler_barrier();
92 *(volatile uint64_t *)addr = data;
93 compiler_barrier();
94}
95#endif /* CONFIG_64BIT */
96
97#ifdef __cplusplus
98}
99#endif
100
101#endif /* _ASMLANGUAGE */
102
103#endif /* ZEPHYR_INCLUDE_ARCH_ARC_SYS_IO_COMMON_H_ */
static ALWAYS_INLINE void sys_write64(uint64_t data, mem_addr_t addr)
Definition sys_io.h:95
static ALWAYS_INLINE uint64_t sys_read64(mem_addr_t addr)
Definition sys_io.h:75
ARCv2 auxiliary registers definitions.
#define ALWAYS_INLINE
Definition common.h:160
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT64_TYPE__ uint64_t
Definition stdint.h:91
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
static ALWAYS_INLINE void sys_write32(uint32_t data, mem_addr_t addr)
Definition sys-io-common.h:70
static ALWAYS_INLINE uint8_t sys_read8(mem_addr_t addr)
Definition sys-io-common.h:23
static ALWAYS_INLINE void sys_write16(uint16_t data, mem_addr_t addr)
Definition sys-io-common.h:52
static ALWAYS_INLINE uint32_t sys_read32(mem_addr_t addr)
Definition sys-io-common.h:59
static ALWAYS_INLINE uint16_t sys_read16(mem_addr_t addr)
Definition sys-io-common.h:41
static ALWAYS_INLINE void sys_write8(uint8_t data, mem_addr_t addr)
Definition sys-io-common.h:34
uintptr_t mem_addr_t
Definition sys_io.h:21
Macros to abstract toolchain specific capabilities.