source: mainline/kernel/arch/sparc64/src/sun4u/sparc64.c@ 34e1206

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 34e1206 was a35b458, checked in by Jiří Zárevúcky <zarevucky.jiri@…>, 8 years ago

style: Remove trailing whitespace on _all_ lines, including empty ones, for particular file types.

Command used: tools/srepl '\s\+$' '' -- *.c *.h *.py *.sh *.s *.S *.ag

Currently, whitespace on empty lines is very inconsistent.
There are two basic choices: Either remove the whitespace, or keep empty lines
indented to the level of surrounding code. The former is AFAICT more common,
and also much easier to do automatically.

Alternatively, we could write script for automatic indentation, and use that
instead. However, if such a script exists, it's possible to use the indented
style locally, by having the editor apply relevant conversions on load/save,
without affecting remote repository. IMO, it makes more sense to adopt
the simpler rule.

  • Property mode set to 100644
File size: 5.4 KB
Line 
1/*
2 * Copyright (c) 2005 Jakub Jermar
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - 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 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup sparc64
30 * @{
31 */
32/** @file
33 */
34
35#include <arch.h>
36#include <arch/arch.h>
37#include <debug.h>
38#include <config.h>
39#include <macros.h>
40#include <arch/trap/trap.h>
41#include <arch/console.h>
42#include <console/console.h>
43#include <arch/boot/boot.h>
44#include <arch/arch.h>
45#include <arch/asm.h>
46#include <arch/mm/page.h>
47#include <arch/stack.h>
48#include <interrupt.h>
49#include <genarch/ofw/ofw_tree.h>
50#include <userspace.h>
51#include <ddi/irq.h>
52#include <str.h>
53#include <sysinfo/sysinfo.h>
54
55static void sun4u_pre_mm_init(void);
56static void sun4u_post_mm_init(void);
57static void sun4u_post_smp_init(void);
58
59arch_ops_t sun4u_ops = {
60 .pre_mm_init = sun4u_pre_mm_init,
61 .post_mm_init = sun4u_post_mm_init,
62 .post_smp_init = sun4u_post_smp_init,
63};
64
65arch_ops_t *sparc64_ops = &sun4u_ops;
66
67memmap_t memmap;
68
69/** Perform sparc64-specific initialization before main_bsp() is called. */
70void sparc64_pre_main(bootinfo_t *bootinfo)
71{
72 /* Copy init task info. */
73 init.cnt = min3(bootinfo->taskmap.cnt, TASKMAP_MAX_RECORDS, CONFIG_INIT_TASKS);
74
75 size_t i;
76 for (i = 0; i < init.cnt; i++) {
77 init.tasks[i].paddr = KA2PA(bootinfo->taskmap.tasks[i].addr);
78 init.tasks[i].size = bootinfo->taskmap.tasks[i].size;
79 str_cpy(init.tasks[i].name, CONFIG_TASK_NAME_BUFLEN,
80 bootinfo->taskmap.tasks[i].name);
81 }
82
83 /* Copy physical memory map. */
84 memmap.total = bootinfo->memmap.total;
85 memmap.cnt = min(bootinfo->memmap.cnt, MEMMAP_MAX_RECORDS);
86 for (i = 0; i < memmap.cnt; i++) {
87 memmap.zones[i].start = bootinfo->memmap.zones[i].start;
88 memmap.zones[i].size = bootinfo->memmap.zones[i].size;
89 }
90
91 /* Copy boot allocations info. */
92 ballocs.base = bootinfo->ballocs.base;
93 ballocs.size = bootinfo->ballocs.size;
94
95 ofw_tree_init(bootinfo->ofw_root);
96}
97
98/** Perform sparc64 specific initialization before mm is initialized. */
99void sun4u_pre_mm_init(void)
100{
101 if (config.cpu_active == 1) {
102 trap_init();
103 exc_arch_init();
104 }
105}
106
107/** Perform sparc64 specific initialization afterr mm is initialized. */
108void sun4u_post_mm_init(void)
109{
110 if (config.cpu_active == 1) {
111 /* Map OFW information into sysinfo */
112 ofw_sysinfo_map();
113
114 /*
115 * We have 2^11 different interrupt vectors.
116 * But we only create 128 buckets.
117 */
118 irq_init(1 << 11, 128);
119 }
120}
121
122void sun4u_post_smp_init(void)
123{
124 /* Currently the only supported platform for sparc64/sun4u is 'sun4u'. */
125 static const char *platform = "sun4u";
126
127 sysinfo_set_item_data("platform", NULL, (void *) platform,
128 str_size(platform));
129
130 standalone_sparc64_console_init();
131}
132
133/** Calibrate delay loop.
134 *
135 * On sparc64, we implement delay() by waiting for the TICK register to
136 * reach a pre-computed value, as opposed to performing some pre-computed
137 * amount of instructions of known duration. We set the delay_loop_const
138 * to 1 in order to neutralize the multiplication done by delay().
139 */
140void calibrate_delay_loop(void)
141{
142 CPU->delay_loop_const = 1;
143}
144
145/** Wait several microseconds.
146 *
147 * We assume that interrupts are already disabled.
148 *
149 * @param t Microseconds to wait.
150 */
151void asm_delay_loop(const uint32_t usec)
152{
153 uint64_t stop = tick_read() + (uint64_t) usec * (uint64_t)
154 CPU->arch.clock_frequency / 1000000;
155
156 while (tick_read() < stop)
157 ;
158}
159
160/** Switch to userspace. */
161void userspace(uspace_arg_t *kernel_uarg)
162{
163 (void) interrupts_disable();
164 switch_to_userspace((uintptr_t) kernel_uarg->uspace_entry,
165 ((uintptr_t) kernel_uarg->uspace_stack) +
166 kernel_uarg->uspace_stack_size -
167 (ALIGN_UP(STACK_ITEM_SIZE, STACK_ALIGNMENT) + STACK_BIAS),
168 (uintptr_t) kernel_uarg->uspace_uarg);
169
170 /* Not reached */
171 while (1);
172}
173
174void arch_reboot(void)
175{
176 // TODO
177 while (1);
178}
179
180/** Construct function pointer
181 *
182 * @param fptr function pointer structure
183 * @param addr function address
184 * @param caller calling function address
185 *
186 * @return address of the function pointer
187 *
188 */
189void *arch_construct_function(fncptr_t *fptr, void *addr, void *caller)
190{
191 return addr;
192}
193
194void irq_initialize_arch(irq_t *irq)
195{
196 (void) irq;
197}
198
199/** @}
200 */
Note: See TracBrowser for help on using the repository browser.