RTEMS 6.1-rc1
atsam-clock-config.h
1/* SPDX-License-Identifier: BSD-2-Clause */
2
3/*
4 * Copyright (c) 2017 embedded brains GmbH & Co. KG
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 * POSSIBILITY OF SUCH DAMAGE.
26 */
27
28#ifndef ATSAM_CLOCK_CONFIG_H
29#define ATSAM_CLOCK_CONFIG_H
30
31#include <rtems.h>
32#include <bsp/linker-symbols.h>
33#include <bspopts.h>
34
35#ifdef __cplusplus
36extern "C" {
37#endif /* __cplusplus */
38
39#if ATSAM_CHANGE_CLOCK_FROM_SRAM != 0
40/* Note: fast_text is the simplest section to put this code into. Other
41 * possibilities would include creating a new section. */
42#define ATSAM_START_SRAM_SECTION BSP_FAST_TEXT_SECTION
43#else
44#define ATSAM_START_SRAM_SECTION
45#endif
46
48 /* Initialization value for the PMC_PLLAR. */
49 uint32_t pllar_init;
50 /* Initialization value for the PMC_MCKR. */
51 uint32_t mckr_init;
52 /* Resulting frequency in Hz. */
53 uint32_t mck_freq;
54};
55
56ATSAM_START_SRAM_SECTION
57extern const struct atsam_clock_config atsam_clock_config;
58
59#define BOARD_MCK (atsam_clock_config.mck_freq)
60
61typedef struct BOARD_Sdram_Config {
62 uint32_t sdramc_tr;
63 uint32_t sdramc_cr;
64 uint32_t sdramc_mdr;
65 uint32_t sdramc_cfr1;
66 uint32_t sdramc_lpr;
68
69ATSAM_START_SRAM_SECTION
71
72#ifdef __cplusplus
73}
74#endif /* __cplusplus */
75
76#endif /* ATSAM_CLOCK_CONFIG_H */
This header file defines the RTEMS Classic API.
Definition: atsam-clock-config.h:61
Definition: atsam-clock-config.h:47