blob: 8542dbc29638af944ecb99f70e5295f51790b829 [file] [log] [blame]
Andrew Scull11a4a0c2018-12-29 11:38:31 +00001/*
Andrew Walbran692b3252019-03-07 15:51:31 +00002 * Copyright 2018 The Hafnium Authors.
Andrew Scull11a4a0c2018-12-29 11:38:31 +00003 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * https://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Andrew Scull9a6384b2019-01-02 12:08:40 +000017#include "hf/arch/cpu.h"
Andrew Scull11a4a0c2018-12-29 11:38:31 +000018
19void arch_irq_disable(void)
20{
21 /* TODO */
22}
23
24void arch_irq_enable(void)
25{
26 /* TODO */
27}
28
Andrew Walbran95534922019-06-19 11:32:54 +010029void arch_regs_reset(struct arch_regs *r, bool is_primary, spci_vm_id_t vm_id,
Andrew Scullbb3ab6c2018-11-26 20:38:49 +000030 uint64_t vcpu_id, paddr_t table)
Andrew Scull11a4a0c2018-12-29 11:38:31 +000031{
32 /* TODO */
33 (void)is_primary;
Andrew Scullbb3ab6c2018-11-26 20:38:49 +000034 (void)vm_id;
Andrew Scull11a4a0c2018-12-29 11:38:31 +000035 (void)table;
Andrew Scullbb3ab6c2018-11-26 20:38:49 +000036 r->vcpu_id = vcpu_id;
Andrew Scull11a4a0c2018-12-29 11:38:31 +000037}
38
39void arch_regs_set_pc_arg(struct arch_regs *r, ipaddr_t pc, uintreg_t arg)
40{
41 (void)pc;
42 r->r[0] = arg;
43}
44
45void arch_regs_set_retval(struct arch_regs *r, uintreg_t v)
46{
47 r->r[0] = v;
48}