diff options
-rw-r--r-- | core/platform.c | 2 | ||||
-rw-r--r-- | hw/Makefile.inc | 2 | ||||
-rw-r--r-- | hw/fake-rtc.c | 69 | ||||
-rw-r--r-- | include/skiboot.h | 2 |
4 files changed, 74 insertions, 1 deletions
diff --git a/core/platform.c b/core/platform.c index e54b334d..9a569192 100644 --- a/core/platform.c +++ b/core/platform.c @@ -50,6 +50,8 @@ opal_call(OPAL_CEC_REBOOT, opal_cec_reboot, 0); static void generic_platform_init(void) { + fake_rtc_init(); + /* Do we want to unconditionally enable it ? */ if (dummy_console_enabled()) dummy_console_add_nodes(); diff --git a/hw/Makefile.inc b/hw/Makefile.inc index 14bf8e78..f1ffe55c 100644 --- a/hw/Makefile.inc +++ b/hw/Makefile.inc @@ -4,7 +4,7 @@ SUBDIRS += hw HW_OBJS = xscom.o chiptod.o gx.o cec.o lpc.o lpc-uart.o psi.o HW_OBJS += homer.o slw.o occ.o nx.o fsi-master.o centaur.o HW_OBJS += p7ioc.o p7ioc-inits.o p7ioc-phb.o p5ioc2.o p5ioc2-phb.o -HW_OBJS += phb3.o sfc-ctrl.o +HW_OBJS += phb3.o sfc-ctrl.o fake-rtc.o HW=hw/built-in.o include $(SRC)/hw/fsp/Makefile.inc diff --git a/hw/fake-rtc.c b/hw/fake-rtc.c new file mode 100644 index 00000000..2aadfa09 --- /dev/null +++ b/hw/fake-rtc.c @@ -0,0 +1,69 @@ +/* Copyright 2013-2014 IBM Corp. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + * implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include <skiboot.h> +#include <opal.h> +#include <mem_region.h> + +//#define DBG(fmt...) printf("FAKERTC: " fmt) +#define DBG(fmt...) do { } while(0) + +uint32_t *fake_ymd; +uint64_t *fake_hmsm; + +static int64_t fake_rtc_write(uint32_t ymd, uint64_t hmsm) +{ + *fake_ymd = ymd; + *fake_hmsm = hmsm; + + return OPAL_SUCCESS; +} + +static int64_t fake_rtc_read(uint32_t *ymd, uint64_t *hmsm) +{ + if (!ymd || !hmsm) + return OPAL_PARAMETER; + + *ymd = *fake_ymd; + *hmsm = *fake_hmsm; + + return OPAL_SUCCESS; +} + +void fake_rtc_init(void) +{ + struct mem_region *rtc_region = NULL; + uint32_t *rtc = NULL; + + /* Read initial values from reserved memory */ + rtc_region = find_mem_region("ibm,fake-rtc"); + + /* Should we register anyway? */ + if (!rtc_region) { + DBG("No initial RTC value found\n"); + return; + } + + rtc = (uint32_t *) rtc_region->start; + + fake_ymd = rtc; + fake_hmsm = ((uint64_t *) &rtc[1]); + + DBG("Init fake RTC to 0x%x 0x%llx\n", *fake_ymd, *fake_hmsm); + + opal_register(OPAL_RTC_READ, fake_rtc_read, 2); + opal_register(OPAL_RTC_WRITE, fake_rtc_write, 2); +} diff --git a/include/skiboot.h b/include/skiboot.h index ddc6b4ac..c879acad 100644 --- a/include/skiboot.h +++ b/include/skiboot.h @@ -214,6 +214,8 @@ extern void *create_dtb(const struct dt_node *root); /* SLW reinit function for switching core settings */ extern int64_t slw_reinit(uint64_t flags); +/* Fallback fake RTC */ +extern void fake_rtc_init(void); #endif /* __SKIBOOT_H */ |