/*- * Copyright (c) 2000 Doug Rabson * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $FreeBSD$ */ #include #include #include #include #include #include #include static void eficlock_init(kobj_t dev) { } /* * Get the time of day, based on the clock's value and/or the base value. */ static void eficlock_get(kobj_t dev, time_t base, struct clocktime *ct) { EFI_TIME time; ia64_efi_runtime->GetTime(&time, 0); ct->sec = time.Second; ct->min = time.Minute; ct->hour = time.Hour; ct->dow = 0; /* XXX not used */ ct->day = time.Day; ct->mon = time.Month; ct->year = time.Year - 1900; } /* * Reset the TODR based on the time value. */ static void eficlock_set(kobj_t dev, struct clocktime *ct) { EFI_TIME time; EFI_STATUS status; ia64_efi_runtime->GetTime(&time, 0); time.Second = ct->sec; time.Minute = ct->min; time.Hour = ct->hour; time.Day = ct->day; time.Month = ct->mon; time.Year = ct->year + 1900; status = ia64_efi_runtime->SetTime(&time); if (status != EFI_SUCCESS) printf("eficlock_set: could not set TODR\n"); } static int eficlock_getsecs(kobj_t dev, int *secp) { return ETIMEDOUT; } static device_method_t eficlock_methods[] = { /* clock interface */ DEVMETHOD(clock_init, eficlock_init), DEVMETHOD(clock_get, eficlock_get), DEVMETHOD(clock_set, eficlock_set), DEVMETHOD(clock_getsecs, eficlock_getsecs), { 0, 0 } }; DEFINE_CLASS(eficlock, eficlock_methods, sizeof(struct kobj)); static void eficlock_create(void *arg) { kobj_t clock; clock = (kobj_t) kobj_create(&eficlock_class, M_TEMP, M_NOWAIT); clockattach(clock); } SYSINIT(eficlock, SI_SUB_DRIVERS,SI_ORDER_MIDDLE, eficlock_create, NULL);