summaryrefslogtreecommitdiffstats
path: root/sys/pc98/cbus/pcrtc.c
diff options
context:
space:
mode:
authorphk <phk@FreeBSD.org>2003-02-05 10:16:43 +0000
committerphk <phk@FreeBSD.org>2003-02-05 10:16:43 +0000
commit025e3741102bdf60e9bff06b28346bb0b457d094 (patch)
tree624d22308bca933d64fc509a29d0f52d46840157 /sys/pc98/cbus/pcrtc.c
parent8ad27b12113fd051d0283174ce0ad8bc1faeb9da (diff)
downloadFreeBSD-src-025e3741102bdf60e9bff06b28346bb0b457d094.zip
FreeBSD-src-025e3741102bdf60e9bff06b28346bb0b457d094.tar.gz
Reduce diff to i386/isa/clock.c by unifdef -DPC98
Diffstat (limited to 'sys/pc98/cbus/pcrtc.c')
-rw-r--r--sys/pc98/cbus/pcrtc.c415
1 files changed, 0 insertions, 415 deletions
diff --git a/sys/pc98/cbus/pcrtc.c b/sys/pc98/cbus/pcrtc.c
index b8e51ed..56ad7c1 100644
--- a/sys/pc98/cbus/pcrtc.c
+++ b/sys/pc98/cbus/pcrtc.c
@@ -85,14 +85,9 @@
#include <machine/specialreg.h>
#include <i386/isa/icu.h>
-#ifdef PC98
#include <pc98/pc98/pc98.h>
#include <pc98/pc98/pc98_machdep.h>
#include <i386/isa/isa_device.h>
-#else
-#include <i386/isa/isa.h>
-#include <isa/rtc.h>
-#endif
#ifdef DEV_ISA
#include <isa/isavar.h>
#endif
@@ -144,11 +139,7 @@ int pscnt = 1;
int psdiv = 1;
int statclock_disable;
#ifndef TIMER_FREQ
-#ifdef PC98
#define TIMER_FREQ 2457600
-#else /* IBM-PC */
-#define TIMER_FREQ 1193182
-#endif /* PC98 */
#endif
u_int timer_freq = TIMER_FREQ;
int timer0_max_count;
@@ -172,10 +163,6 @@ static int i8254_ticked;
*/
static void (*new_function)(struct clockframe *frame);
static u_int new_rate;
-#ifndef PC98
-static u_char rtc_statusa = RTCSA_DIVIDER | RTCSA_NOPROF;
-static u_char rtc_statusb = RTCSB_24HR | RTCSB_PINTR;
-#endif
static u_int timer0_prescaler_count;
/* Values for timerX_state: */
@@ -185,17 +172,13 @@ static u_int timer0_prescaler_count;
#define ACQUIRE_PENDING 3
static u_char timer0_state;
-#ifdef PC98
static u_char timer1_state;
-#endif
static u_char timer2_state;
static void (*timer_func)(struct clockframe *frame) = hardclock;
-#ifdef PC98
static void rtc_serialcombit(int);
static void rtc_serialcom(int);
static int rtc_inb(void);
static void rtc_outb(int);
-#endif
static unsigned i8254_get_timecount(struct timecounter *tc);
static unsigned tsc_get_timecount(struct timecounter *tc);
@@ -331,7 +314,6 @@ acquire_timer0(int rate, void (*function)(struct clockframe *frame))
return (0);
}
-#ifdef PC98
int
acquire_timer1(int mode)
{
@@ -351,7 +333,6 @@ acquire_timer1(int mode)
return (0);
}
-#endif
int
acquire_timer2(int mode)
@@ -393,7 +374,6 @@ release_timer0()
return (0);
}
-#ifdef PC98
int
release_timer1()
{
@@ -404,7 +384,6 @@ release_timer1()
outb(TIMER_MODE, TIMER_SEL1 | TIMER_SQWAVE | TIMER_16BIT);
return (0);
}
-#endif
int
release_timer2()
@@ -417,58 +396,6 @@ release_timer2()
return (0);
}
-#ifndef PC98
-/*
- * This routine receives statistical clock interrupts from the RTC.
- * As explained above, these occur at 128 interrupts per second.
- * When profiling, we receive interrupts at a rate of 1024 Hz.
- *
- * This does not actually add as much overhead as it sounds, because
- * when the statistical clock is active, the hardclock driver no longer
- * needs to keep (inaccurate) statistics on its own. This decouples
- * statistics gathering from scheduling interrupts.
- *
- * The RTC chip requires that we read status register C (RTC_INTR)
- * to acknowledge an interrupt, before it will generate the next one.
- * Under high interrupt load, rtcintr() can be indefinitely delayed and
- * the clock can tick immediately after the read from RTC_INTR. In this
- * case, the mc146818A interrupt signal will not drop for long enough
- * to register with the 8259 PIC. If an interrupt is missed, the stat
- * clock will halt, considerably degrading system performance. This is
- * why we use 'while' rather than a more straightforward 'if' below.
- * Stat clock ticks can still be lost, causing minor loss of accuracy
- * in the statistics, but the stat clock will no longer stop.
- */
-static void
-rtcintr(struct clockframe frame)
-{
- while (rtcin(RTC_INTR) & RTCIR_PERIOD) {
- if (profprocs != 0) {
- if (--pscnt == 0)
- pscnt = psdiv;
- profclock(&frame);
- }
- if (pscnt == psdiv)
- statclock(&frame);
-#ifdef SMP
- forward_statclock();
-#endif
- }
-}
-
-#include "opt_ddb.h"
-#ifdef DDB
-#include <ddb/ddb.h>
-
-DB_SHOW_COMMAND(rtc, rtc)
-{
- printf("%02x/%02x/%02x %02x:%02x:%02x, A = %02x, B = %02x, C = %02x\n",
- rtcin(RTC_YEAR), rtcin(RTC_MONTH), rtcin(RTC_DAY),
- rtcin(RTC_HRS), rtcin(RTC_MIN), rtcin(RTC_SEC),
- rtcin(RTC_STATUSA), rtcin(RTC_STATUSB), rtcin(RTC_INTR));
-}
-#endif /* DDB */
-#endif /* for PC98 */
static int
getit(void)
@@ -581,13 +508,8 @@ DELAY(int n)
static void
sysbeepstop(void *chan)
{
-#ifdef PC98 /* PC98 */
outb(IO_PPI, inb(IO_PPI)|0x08); /* disable counter1 output to speaker */
release_timer1();
-#else
- outb(IO_PPI, inb(IO_PPI)&0xFC); /* disable counter2 output to speaker */
- release_timer2();
-#endif
beeping = 0;
}
@@ -596,7 +518,6 @@ sysbeep(int pitch, int period)
{
int x = splclock();
-#ifdef PC98
if (acquire_timer1(TIMER_SQWAVE|TIMER_16BIT))
if (!beeping) {
/* Something else owns it. */
@@ -613,71 +534,11 @@ sysbeep(int pitch, int period)
beeping = period;
timeout(sysbeepstop, (void *)NULL, period);
}
-#else
- if (acquire_timer2(TIMER_SQWAVE|TIMER_16BIT))
- if (!beeping) {
- /* Something else owns it. */
- splx(x);
- return (-1); /* XXX Should be EBUSY, but nobody cares anyway. */
- }
- mtx_lock_spin(&clock_lock);
- outb(TIMER_CNTR2, pitch);
- outb(TIMER_CNTR2, (pitch>>8));
- mtx_unlock_spin(&clock_lock);
- if (!beeping) {
- /* enable counter2 output to speaker */
- outb(IO_PPI, inb(IO_PPI) | 3);
- beeping = period;
- timeout(sysbeepstop, (void *)NULL, period);
- }
-#endif
splx(x);
return (0);
}
-#ifndef PC98
-/*
- * RTC support routines
- */
-
-int
-rtcin(reg)
- int reg;
-{
- int s;
- u_char val;
-
- s = splhigh();
- outb(IO_RTC, reg);
- inb(0x84);
- val = inb(IO_RTC + 1);
- inb(0x84);
- splx(s);
- return (val);
-}
-
-static __inline void
-writertc(u_char reg, u_char val)
-{
- int s;
-
- s = splhigh();
- inb(0x84);
- outb(IO_RTC, reg);
- inb(0x84);
- outb(IO_RTC + 1, val);
- inb(0x84); /* XXX work around wrong order in rtcin() */
- splx(s);
-}
-
-static __inline int
-readrtc(int port)
-{
- return(bcd2bin(rtcin(port)));
-}
-#endif
-#ifdef PC98
unsigned int delaycount;
#define FIRST_GUESS 0x2000
static void findcpuspeed(void)
@@ -694,9 +555,7 @@ static void findcpuspeed(void)
remainder = getit();
delaycount = (FIRST_GUESS * TIMER_DIV(1000)) / (0xffff - remainder);
}
-#endif
-#ifdef PC98
static u_int
calibrate_clocks(void)
{
@@ -769,102 +628,6 @@ fail:
timer_freq);
return (timer_freq);
}
-#else
-static u_int
-calibrate_clocks(void)
-{
- u_int64_t old_tsc;
- u_int count, prev_count, tot_count;
- int sec, start_sec, timeout;
-
- if (bootverbose)
- printf("Calibrating clock(s) ... ");
- if (!(rtcin(RTC_STATUSD) & RTCSD_PWR))
- goto fail;
- timeout = 100000000;
-
- /* Read the mc146818A seconds counter. */
- for (;;) {
- if (!(rtcin(RTC_STATUSA) & RTCSA_TUP)) {
- sec = rtcin(RTC_SEC);
- break;
- }
- if (--timeout == 0)
- goto fail;
- }
-
- /* Wait for the mC146818A seconds counter to change. */
- start_sec = sec;
- for (;;) {
- if (!(rtcin(RTC_STATUSA) & RTCSA_TUP)) {
- sec = rtcin(RTC_SEC);
- if (sec != start_sec)
- break;
- }
- if (--timeout == 0)
- goto fail;
- }
-
- /* Start keeping track of the i8254 counter. */
- prev_count = getit();
- if (prev_count == 0 || prev_count > timer0_max_count)
- goto fail;
- tot_count = 0;
-
- if (tsc_present)
- old_tsc = rdtsc();
- else
- old_tsc = 0; /* shut up gcc */
-
- /*
- * Wait for the mc146818A seconds counter to change. Read the i8254
- * counter for each iteration since this is convenient and only
- * costs a few usec of inaccuracy. The timing of the final reads
- * of the counters almost matches the timing of the initial reads,
- * so the main cause of inaccuracy is the varying latency from
- * inside getit() or rtcin(RTC_STATUSA) to the beginning of the
- * rtcin(RTC_SEC) that returns a changed seconds count. The
- * maximum inaccuracy from this cause is < 10 usec on 486's.
- */
- start_sec = sec;
- for (;;) {
- if (!(rtcin(RTC_STATUSA) & RTCSA_TUP))
- sec = rtcin(RTC_SEC);
- count = getit();
- if (count == 0 || count > timer0_max_count)
- goto fail;
- if (count > prev_count)
- tot_count += prev_count - (count - timer0_max_count);
- else
- tot_count += prev_count - count;
- prev_count = count;
- if (sec != start_sec)
- break;
- if (--timeout == 0)
- goto fail;
- }
-
- /*
- * Read the cpu cycle counter. The timing considerations are
- * similar to those for the i8254 clock.
- */
- if (tsc_present)
- tsc_freq = rdtsc() - old_tsc;
-
- if (bootverbose) {
- if (tsc_present)
- printf("TSC clock: %ju Hz, ", (intmax_t)tsc_freq);
- printf("i8254 clock: %u Hz\n", tot_count);
- }
- return (tot_count);
-
-fail:
- if (bootverbose)
- printf("failed, using default i8254 clock of %u Hz\n",
- timer_freq);
- return (timer_freq);
-}
-#endif /* !PC98 */
static void
set_timer_freq(u_int freq, int intr_freq)
@@ -894,18 +657,6 @@ i8254_restore(void)
mtx_unlock_spin(&clock_lock);
}
-#ifndef PC98
-static void
-rtc_restore(void)
-{
-
- /* Restore all of the RTC's "status" (actually, control) registers. */
- /* XXX locking is needed for RTC access. */
- writertc(RTC_STATUSB, RTCSB_24HR);
- writertc(RTC_STATUSA, rtc_statusa);
- writertc(RTC_STATUSB, rtc_statusb);
-}
-#endif
/*
* Restore all the timers non-atomically (XXX: should be atomically).
@@ -919,9 +670,6 @@ timer_restore(void)
{
i8254_restore(); /* restore timer_freq and hz */
-#ifndef PC98
- rtc_restore(); /* reenable RTC interrupts */
-#endif
}
/*
@@ -933,23 +681,17 @@ startrtclock()
{
u_int delta, freq;
-#ifdef PC98
findcpuspeed();
if (pc98_machine_type & M_8M)
timer_freq = 1996800L; /* 1.9968 MHz */
else
timer_freq = 2457600L; /* 2.4576 MHz */
-#endif /* PC98 */
if (cpu_feature & CPUID_TSC)
tsc_present = 1;
else
tsc_present = 0;
-#ifndef PC98
- writertc(RTC_STATUSA, rtc_statusa);
- writertc(RTC_STATUSB, RTCSB_24HR);
-#endif
set_timer_freq(timer_freq, hz);
freq = calibrate_clocks();
@@ -1045,7 +787,6 @@ startrtclock()
#endif /* !defined(SMP) */
}
-#ifdef PC98
static void
rtc_serialcombit(int i)
{
@@ -1103,7 +844,6 @@ rtc_inb(void)
}
return sa;
}
-#endif /* PC-98 */
/*
* Initialize the time of day register, based on the time base which is, e.g.
@@ -1116,9 +856,7 @@ inittodr(time_t base)
int year, month;
int y, m, s;
struct timespec ts;
-#ifdef PC98
int second, min, hour;
-#endif
if (base) {
s = splclock();
@@ -1128,7 +866,6 @@ inittodr(time_t base)
splx(s);
}
-#ifdef PC98
rtc_serialcom(0x03); /* Time Read */
rtc_serialcom(0x01); /* Register shift command. */
DELAY(20);
@@ -1159,46 +896,6 @@ inittodr(time_t base)
in the local time zone */
s = splhigh();
-#else /* IBM-PC */
- /* Look if we have a RTC present and the time is valid */
- if (!(rtcin(RTC_STATUSD) & RTCSD_PWR))
- goto wrong_time;
-
- /* wait for time update to complete */
- /* If RTCSA_TUP is zero, we have at least 244us before next update */
- s = splhigh();
- while (rtcin(RTC_STATUSA) & RTCSA_TUP) {
- splx(s);
- s = splhigh();
- }
-
- days = 0;
-#ifdef USE_RTC_CENTURY
- year = readrtc(RTC_YEAR) + readrtc(RTC_CENTURY) * 100;
-#else
- year = readrtc(RTC_YEAR) + 1900;
- if (year < 1970)
- year += 100;
-#endif
- if (year < 1970) {
- splx(s);
- goto wrong_time;
- }
- month = readrtc(RTC_MONTH);
- for (m = 1; m < month; m++)
- days += daysinmonth[m-1];
- if ((month > 2) && LEAPYEAR(year))
- days ++;
- days += readrtc(RTC_DAY) - 1;
- for (y = 1970; y < year; y++)
- days += DAYSPERYEAR + LEAPYEAR(y);
- sec = ((( days * 24 +
- readrtc(RTC_HRS)) * 60 +
- readrtc(RTC_MIN)) * 60 +
- readrtc(RTC_SEC));
- /* sec now contains the number of seconds, since Jan 1 1970,
- in the local time zone */
-#endif
sec += tz_minuteswest * 60 + (wall_cmos_clock ? adjkerntz : 0);
@@ -1225,9 +922,7 @@ resettodr()
{
unsigned long tm;
int y, m, s;
-#ifdef PC98
int wd;
-#endif
if (disable_rtc_set)
return;
@@ -1236,7 +931,6 @@ resettodr()
tm = time_second;
splx(s);
-#ifdef PC98
rtc_serialcom(0x01); /* Register shift command. */
/* Calculate local time to put in RTC */
@@ -1273,47 +967,6 @@ resettodr()
rtc_serialcom(0x02); /* Time set & Counter hold command. */
rtc_serialcom(0x00); /* Register hold command. */
-#else
- /* Disable RTC updates and interrupts. */
- writertc(RTC_STATUSB, RTCSB_HALT | RTCSB_24HR);
-
- /* Calculate local time to put in RTC */
-
- tm -= tz_minuteswest * 60 + (wall_cmos_clock ? adjkerntz : 0);
-
- writertc(RTC_SEC, bin2bcd(tm%60)); tm /= 60; /* Write back Seconds */
- writertc(RTC_MIN, bin2bcd(tm%60)); tm /= 60; /* Write back Minutes */
- writertc(RTC_HRS, bin2bcd(tm%24)); tm /= 24; /* Write back Hours */
-
- /* We have now the days since 01-01-1970 in tm */
- writertc(RTC_WDAY, (tm+4)%7); /* Write back Weekday */
- for (y = 1970, m = DAYSPERYEAR + LEAPYEAR(y);
- tm >= m;
- y++, m = DAYSPERYEAR + LEAPYEAR(y))
- tm -= m;
-
- /* Now we have the years in y and the day-of-the-year in tm */
- writertc(RTC_YEAR, bin2bcd(y%100)); /* Write back Year */
-#ifdef USE_RTC_CENTURY
- writertc(RTC_CENTURY, bin2bcd(y/100)); /* ... and Century */
-#endif
- for (m = 0; ; m++) {
- int ml;
-
- ml = daysinmonth[m];
- if (m == 1 && LEAPYEAR(y))
- ml++;
- if (tm < ml)
- break;
- tm -= ml;
- }
-
- writertc(RTC_MONTH, bin2bcd(m + 1)); /* Write back Month */
- writertc(RTC_DAY, bin2bcd(tm + 1)); /* Write back Month Day */
-
- /* Reenable RTC updates and interrupts. */
- writertc(RTC_STATUSB, rtc_statusb);
-#endif /* PC98 */
}
@@ -1323,30 +976,12 @@ resettodr()
void
cpu_initclocks()
{
-#ifndef PC98
- int diag;
-#endif
#ifdef APIC_IO
int apic_8254_trial;
void *clkdesc;
#endif /* APIC_IO */
register_t crit;
-#ifndef PC98
- if (statclock_disable) {
- /*
- * The stat interrupt mask is different without the
- * statistics clock. Also, don't set the interrupt
- * flag which would normally cause the RTC to generate
- * interrupts.
- */
- rtc_statusb = RTCSB_24HR;
- } else {
- /* Setting stathz to nonzero early helps avoid races. */
- stathz = RTC_NOPROFRATE;
- profhz = RTC_PROFRATE;
- }
-#endif
/* Finish initializing 8253 timer 0. */
#ifdef APIC_IO
@@ -1390,40 +1025,7 @@ cpu_initclocks()
#endif /* APIC_IO */
-#ifndef PC98
- /* Initialize RTC. */
- writertc(RTC_STATUSA, rtc_statusa);
- writertc(RTC_STATUSB, RTCSB_24HR);
- /* Don't bother enabling the statistics clock. */
- if (statclock_disable)
- return;
- diag = rtcin(RTC_DIAG);
- if (diag != 0)
- printf("RTC BIOS diagnostic error %b\n", diag, RTCDG_BITS);
-#endif /* !PC98 */
-
-#ifndef PC98
-#ifdef APIC_IO
- if (isa_apic_irq(8) != 8)
- panic("APIC RTC != 8");
-#endif /* APIC_IO */
-
- inthand_add("rtc", 8, (driver_intr_t *)rtcintr, NULL,
- INTR_TYPE_CLK | INTR_FAST, NULL);
-
- crit = intr_disable();
- mtx_lock_spin(&icu_lock);
-#ifdef APIC_IO
- INTREN(APIC_IRQ8);
-#else
- INTREN(IRQ8);
-#endif /* APIC_IO */
- mtx_unlock_spin(&icu_lock);
- intr_restore(crit);
-
- writertc(RTC_STATUSB, rtc_statusb);
-#endif /* PC98 */
#ifdef APIC_IO
if (apic_8254_trial) {
@@ -1507,17 +1109,10 @@ setup_8254_mixed_mode()
* reset; prog 4 bytes, single ICU, edge triggered
*/
outb(IO_ICU1, 0x13);
-#ifdef PC98
outb(IO_ICU1 + 2, NRSVIDT); /* start vector (unused) */
outb(IO_ICU1 + 2, 0x00); /* ignore slave */
outb(IO_ICU1 + 2, 0x03); /* auto EOI, 8086 */
outb(IO_ICU1 + 2, 0xfe); /* unmask INT0 */
-#else
- outb(IO_ICU1 + 1, NRSVIDT); /* start vector (unused) */
- outb(IO_ICU1 + 1, 0x00); /* ignore slave */
- outb(IO_ICU1 + 1, 0x03); /* auto EOI, 8086 */
- outb(IO_ICU1 + 1, 0xfe); /* unmask INT0 */
-#endif
/* program IO APIC for type 3 INT on INT0 */
if (ext_int_setup(0, 0) < 0)
@@ -1528,13 +1123,6 @@ setup_8254_mixed_mode()
void
cpu_startprofclock(void)
{
-#ifndef PC98
- if (newhz == RTC_PROFRATE)
- rtc_statusa = RTCSA_DIVIDER | RTCSA_PROF;
- else
- rtc_statusa = RTCSA_DIVIDER | RTCSA_NOPROF;
- writertc(RTC_STATUSA, rtc_statusa);
-#endif
}
void
@@ -1674,7 +1262,4 @@ static driver_t attimer_driver = {
static devclass_t attimer_devclass;
DRIVER_MODULE(attimer, isa, attimer_driver, attimer_devclass, 0, 0);
-#ifndef PC98
-DRIVER_MODULE(attimer, acpi, attimer_driver, attimer_devclass, 0, 0);
-#endif
#endif /* DEV_ISA */
OpenPOWER on IntegriCloud