source: mainline/kernel/arch/ppc32/src/context.S@ 8c7d5ad

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

Autogenerate ppc32 kernel context_t and fpu_context_t and their offsets.

  • Property mode set to 100644
File size: 3.2 KB
Line 
1#
2# Copyright (c) 2005 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
29#include <arch/context_struct.h>
30#include <arch/asm/regname.h>
31
32.text
33
34.global context_save_arch
35.global context_restore_arch
36
37context_save_arch:
38 stw sp, CONTEXT_OFFSET_SP(r3)
39 stw r2, CONTEXT_OFFSET_R2(r3)
40 stw r13, CONTEXT_OFFSET_R13(r3)
41 stw r14, CONTEXT_OFFSET_R14(r3)
42 stw r15, CONTEXT_OFFSET_R15(r3)
43 stw r16, CONTEXT_OFFSET_R16(r3)
44 stw r17, CONTEXT_OFFSET_R17(r3)
45 stw r18, CONTEXT_OFFSET_R18(r3)
46 stw r19, CONTEXT_OFFSET_R19(r3)
47 stw r20, CONTEXT_OFFSET_R20(r3)
48 stw r21, CONTEXT_OFFSET_R21(r3)
49 stw r22, CONTEXT_OFFSET_R22(r3)
50 stw r23, CONTEXT_OFFSET_R23(r3)
51 stw r24, CONTEXT_OFFSET_R24(r3)
52 stw r25, CONTEXT_OFFSET_R25(r3)
53 stw r26, CONTEXT_OFFSET_R26(r3)
54 stw r27, CONTEXT_OFFSET_R27(r3)
55 stw r28, CONTEXT_OFFSET_R28(r3)
56 stw r29, CONTEXT_OFFSET_R29(r3)
57 stw r30, CONTEXT_OFFSET_R30(r3)
58 stw r31, CONTEXT_OFFSET_R31(r3)
59
60 mflr r4
61 stw r4, CONTEXT_OFFSET_PC(r3)
62
63 mfcr r4
64 stw r4, CONTEXT_OFFSET_CR(r3)
65
66 # context_save returns 1
67 li r3, 1
68 blr
69
70context_restore_arch:
71 lwz sp, CONTEXT_OFFSET_SP(r3)
72 lwz r2, CONTEXT_OFFSET_R2(r3)
73 lwz r13, CONTEXT_OFFSET_R13(r3)
74 lwz r14, CONTEXT_OFFSET_R14(r3)
75 lwz r15, CONTEXT_OFFSET_R15(r3)
76 lwz r16, CONTEXT_OFFSET_R16(r3)
77 lwz r17, CONTEXT_OFFSET_R17(r3)
78 lwz r18, CONTEXT_OFFSET_R18(r3)
79 lwz r19, CONTEXT_OFFSET_R19(r3)
80 lwz r20, CONTEXT_OFFSET_R20(r3)
81 lwz r21, CONTEXT_OFFSET_R21(r3)
82 lwz r22, CONTEXT_OFFSET_R22(r3)
83 lwz r23, CONTEXT_OFFSET_R23(r3)
84 lwz r24, CONTEXT_OFFSET_R24(r3)
85 lwz r25, CONTEXT_OFFSET_R25(r3)
86 lwz r26, CONTEXT_OFFSET_R26(r3)
87 lwz r27, CONTEXT_OFFSET_R27(r3)
88 lwz r28, CONTEXT_OFFSET_R28(r3)
89 lwz r29, CONTEXT_OFFSET_R29(r3)
90 lwz r30, CONTEXT_OFFSET_R30(r3)
91 lwz r31, CONTEXT_OFFSET_R31(r3)
92
93 lwz r4, CONTEXT_OFFSET_CR(r3)
94 mtcr r4
95
96 lwz r4, CONTEXT_OFFSET_PC(r3)
97 mtlr r4
98
99 # context_restore returns 0
100 li r3, 0
101 blr
Note: See TracBrowser for help on using the repository browser.