source: mainline/kernel/arch/abs32le/src/abs32le.c@ e88eb48

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since e88eb48 was c5429fe, checked in by Jakub Jermar <jakub@…>, 7 years ago

Disambiguate architecture specific doxygroups

  • Property mode set to 100644
File size: 3.1 KB
RevLine 
[50fda24]1/*
2 * Copyright (c) 2010 Martin Decky
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
[c5429fe]29/** @addtogroup kernel_abs32le
[50fda24]30 * @{
31 */
32/** @file
33 */
34
35#include <arch.h>
[d99c1d2]36#include <typedefs.h>
[50fda24]37#include <arch/interrupt.h>
38#include <arch/asm.h>
39
[b2e121a]40#include <halt.h>
[50fda24]41#include <config.h>
[44a7ee5]42#include <console/console.h>
[fb52db8]43#include <errno.h>
[d32358f]44#include <context.h>
[fb52db8]45#include <fpu_context.h>
[50fda24]46#include <interrupt.h>
47#include <ddi/irq.h>
[44a7ee5]48#include <syscall/copy.h>
[50fda24]49#include <syscall/syscall.h>
50
[36df4109]51static void abs32le_post_mm_init(void);
52
53arch_ops_t abs32le_ops = {
54 .post_mm_init = abs32le_post_mm_init,
55};
56
57arch_ops_t *arch_ops = &abs32le_ops;
58
[fb52db8]59char memcpy_from_uspace_failover_address;
60char memcpy_to_uspace_failover_address;
61
[36df4109]62void abs32le_post_mm_init(void)
[50fda24]63{
64 if (config.cpu_active == 1) {
65 /* Initialize IRQ routing */
66 irq_init(0, 0);
[a35b458]67
[50fda24]68 /* Merge all memory zones to 1 big zone */
69 zone_merge_all();
70 }
71}
72
73void calibrate_delay_loop(void)
74{
75}
76
77/** Construct function pointer
78 *
79 * @param fptr function pointer structure
80 * @param addr function address
81 * @param caller calling function address
82 *
83 * @return address of the function pointer
84 *
85 */
86void *arch_construct_function(fncptr_t *fptr, void *addr, void *caller)
87{
88 return addr;
89}
90
91void arch_reboot(void)
92{
93}
94
[3a2f8aa]95void irq_initialize_arch(irq_t *irq)
96{
97 (void) irq;
98}
99
[4fe907b9]100void istate_decode(istate_t *istate)
101{
102 (void) istate;
[c1d3549]103}
104
[d32358f]105int context_save_arch(context_t *ctx)
106{
[ee6f434]107 return EOK;
[d32358f]108}
109
110void context_restore_arch(context_t *ctx)
111{
[1433ecda]112 while (true)
113 ;
[d32358f]114}
115
[fb52db8]116void fpu_init(void)
117{
118}
119
120void fpu_context_save(fpu_context_t *ctx)
121{
122}
123
124void fpu_context_restore(fpu_context_t *ctx)
125{
126}
127
[fac0ac7]128uintptr_t memcpy_from_uspace(void *dst, const void *uspace_src, size_t size)
[fb52db8]129{
[fac0ac7]130 return 0;
[fb52db8]131}
132
[fac0ac7]133uintptr_t memcpy_to_uspace(void *uspace_dst, const void *src, size_t size)
[fb52db8]134{
[fac0ac7]135 return 0;
[fb52db8]136}
137
[ed88c8e]138void early_putwchar(wchar_t ch)
[da52547]139{
140}
141
[50fda24]142/** @}
143 */
Note: See TracBrowser for help on using the repository browser.