aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHelge Deller <deller@gmx.de>2019-10-20 22:01:11 +0200
committerGitHub <noreply@github.com>2019-10-20 22:01:11 +0200
commit84ebfe169c7854b64400dfa4372f5c422c45cdff (patch)
tree60b2befc3e4a7863ff9e4a67c62f970ed25a49f1
parent1527660fbf8511971e97b6b6c01e272eba225c75 (diff)
parent4d130001ffc29dd9e2cc44af26647d0ea9a29bb3 (diff)
downloadseabios-hppa-parisc-qemu-4.1.0.zip
seabios-hppa-parisc-qemu-4.1.0.tar.gz
seabios-hppa-parisc-qemu-4.1.0.tar.bz2
Merge pull request #4 from svenschnelle/parisc-qemu-4.1.0parisc-qemu-4.1.0
STI support and LASI RTC fixes
-rw-r--r--src/parisc/hppa_hardware.h1
-rw-r--r--src/parisc/parisc.c97
-rw-r--r--src/parisc/stirom.c64
3 files changed, 58 insertions, 104 deletions
diff --git a/src/parisc/hppa_hardware.h b/src/parisc/hppa_hardware.h
index 28be7d1..a92bb39 100644
--- a/src/parisc/hppa_hardware.h
+++ b/src/parisc/hppa_hardware.h
@@ -26,6 +26,7 @@
#define LASI_UART_HPA 0xffd05000
#define LASI_SCSI_HPA 0xffd06000
#define LASI_LAN_HPA 0xffd07000
+#define LASI_RTC_HPA 0xffd09000
#define LASI_LPT_HPA 0xffd02000
#define LASI_AUDIO_HPA 0xffd04000
#define LASI_PS2KBD_HPA 0xffd08000
diff --git a/src/parisc/parisc.c b/src/parisc/parisc.c
index fa74344..f16ecd0 100644
--- a/src/parisc/parisc.c
+++ b/src/parisc/parisc.c
@@ -684,94 +684,14 @@ static void init_stable_storage(void)
stable_storage[0x5f] = 0x0f;
}
-
-/*
- * Trivial time conversion helper functions.
- * Not accurate before year 2000 and beyond year 2099.
- * Taken from:
- * https://codereview.stackexchange.com/questions/38275/convert-between-date-time-and-time-stamp-without-using-standard-library-routines
- */
-
-static unsigned short days[4][12] =
+static unsigned long lasi_rtc_read(void)
{
- { 0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335},
- { 366, 397, 425, 456, 486, 517, 547, 578, 609, 639, 670, 700},
- { 731, 762, 790, 821, 851, 882, 912, 943, 974,1004,1035,1065},
- {1096,1127,1155,1186,1216,1247,1277,1308,1339,1369,1400,1430},
-};
-
-static inline int rtc_from_bcd(int a)
-{
- return ((a >> 4) * 10) + (a & 0x0f);
+ return *(u32 *)LASI_RTC_HPA;
}
-#define SECONDS_2000_JAN_1 946684800
-/* assumption: only dates between 01/01/2000 and 31/12/2099 */
-
-static unsigned long seconds_since_1970(void)
+static void lasi_rtc_write(u32 val)
{
- unsigned long ret;
- unsigned int second = rtc_from_bcd(rtc_read(CMOS_RTC_SECONDS));
- unsigned int minute = rtc_from_bcd(rtc_read(CMOS_RTC_MINUTES));
- unsigned int hour = rtc_from_bcd(rtc_read(CMOS_RTC_HOURS));
- unsigned int day = rtc_from_bcd(rtc_read(CMOS_RTC_DAY_MONTH)) - 1;
- unsigned int month = rtc_from_bcd(rtc_read(CMOS_RTC_MONTH)) - 1;
- unsigned int year = rtc_from_bcd(rtc_read(CMOS_RTC_YEAR));
- ret = (((year/4*(365*4+1)+days[year%4][month]+day)*24+hour)*60+minute)
- *60+second + SECONDS_2000_JAN_1;
-
- if (year >= 100)
- printf("\nSeaBIOS WARNING: READ RTC_YEAR=%d is above year 2100.\n", year);
-
- return ret;
-}
-
-static inline int rtc_to_bcd(int a)
-{
- return ((a / 10) << 4) | (a % 10);
-}
-
-int epoch_to_date_time(unsigned long epoch)
-{
- epoch -= SECONDS_2000_JAN_1;
-
- unsigned int second = epoch%60; epoch /= 60;
- unsigned int minute = epoch%60; epoch /= 60;
- unsigned int hour = epoch%24; epoch /= 24;
-
- unsigned int years = epoch/(365*4+1)*4; epoch %= 365*4+1;
-
- unsigned int year;
- for (year=3; year>0; year--)
- {
- if (epoch >= days[year][0])
- break;
- }
-
- unsigned int month;
- for (month=11; month>0; month--)
- {
- if (epoch >= days[year][month])
- break;
- }
-
- unsigned int rtc_year = years + year;
- unsigned int rtc_month = month + 1;
- unsigned int rtc_day = epoch - days[year][month] + 1;
-
- /* set date into RTC */
- rtc_write(CMOS_RTC_SECONDS, rtc_to_bcd(second));
- rtc_write(CMOS_RTC_MINUTES, rtc_to_bcd(minute));
- rtc_write(CMOS_RTC_HOURS, rtc_to_bcd(hour));
- rtc_write(CMOS_RTC_DAY_MONTH, rtc_to_bcd(rtc_day));
- rtc_write(CMOS_RTC_MONTH, rtc_to_bcd(rtc_month));
- if (rtc_year < 100) { /* < year 2100? */
- rtc_write(CMOS_RTC_YEAR, rtc_to_bcd(rtc_year));
- return PDC_OK;
- }
-
- printf("\nSeaBIOS WARNING: WRITE RTC_YEAR=%d above year 2100.\n", rtc_year);
- return PDC_INVALID_ARG;
+ *(u32 *)LASI_RTC_HPA = val;
}
/* values in PDC_CHASSIS */
@@ -1075,15 +995,12 @@ static int pdc_tod(unsigned int *arg)
switch (option) {
case PDC_TOD_READ:
- result[0] = seconds_since_1970();
+ result[0] = lasi_rtc_read();
result[1] = result[2] = result[3] = 0;
return PDC_OK;
case PDC_TOD_WRITE:
- // HP-UX 10.20 tries to write TOD clock with too small values (e.g. 0x432e)...
- if (ARG2 < SECONDS_2000_JAN_1)
- return PDC_INVALID_ARG;
- /* we ignore the usecs in ARG3 */
- return epoch_to_date_time(ARG2);
+ lasi_rtc_write(ARG2);
+ return PDC_OK;
case 2: /* PDC_TOD_CALIBRATE_TIMERS */
/* double-precision floating-point with frequency of Interval Timer in megahertz: */
*(double*)&result[0] = (double)CPU_CLOCK_MHZ;
diff --git a/src/parisc/stirom.c b/src/parisc/stirom.c
index feaadd9..6757fb5 100644
--- a/src/parisc/stirom.c
+++ b/src/parisc/stirom.c
@@ -303,8 +303,11 @@ static const struct font __stidata sti_rom_font = {
}
};
-static const mon_tbl_desc __stidata sti_mon_table[1] = {
- { .x = 1280, .y = 1024, .hz = 70, .class_vesa = 1, .index = 0 }
+static const mon_tbl_desc __stidata sti_mon_table[] = {
+ { .x = 1280, .y = 1024, .hz = 72, .class_vesa = 1, .index = 0 },
+ { .x = 1024, .y = 768, .hz = 72, .class_vesa = 1, .index = 0 },
+ { .x = 768, .y = 600, .hz = 72, .class_vesa = 1, .index = 0 },
+ { .x = 640, .y = 480, .hz = 72, .class_vesa = 1, .index = 0 },
};
struct sti_rom __stiheader sti_proc_rom = {
@@ -395,17 +398,21 @@ static int __stifunc("init_graph") sti_init_graph(struct sti_init_flags *flags,
struct sti_glob_cfg *cfg)
{
u32 *cmap = (u32 *)cfg->region_ptrs[1];
+ u32 resolution = *(u32 *)(cfg->region_ptrs[2] + 0x111110);
out->errno = 0;
- out->text_planes = in->text_planes;
+ if (resolution & (1 << 31)) {
+ cfg->text_planes = 1;
+ } else {
+ out->text_planes = in->text_planes;
+ }
- cfg->text_planes = 8;
- cfg->onscreen_x = 1280;
- cfg->onscreen_y = 1024;
+ cfg->onscreen_x = (resolution >> 16) & 0xfff;
+ cfg->onscreen_y = resolution & 0xfff;
cfg->offscreen_x = 0;
cfg->offscreen_y = 0;
- cfg->total_x = 1280;
- cfg->total_y = 1024;
+ cfg->total_x = cfg->onscreen_x;
+ cfg->total_y = cfg->onscreen_y;
if (flags->clear) {
/* clear screen */
@@ -461,7 +468,7 @@ static __stifunc("inq_conf") int sti_inq_conf(struct sti_conf_flags *flags,
out->total_x = cfg->total_x;
out->total_y = cfg->total_y;
out->bits_per_pixel = 8;
- out->planes = 8;
+ out->planes = cfg->text_planes;
out->dev_name[0] = 'H';
out->dev_name[1] = 'P';
out->dev_name[2] = 'A';
@@ -470,11 +477,40 @@ static __stifunc("inq_conf") int sti_inq_conf(struct sti_conf_flags *flags,
out->dev_name[5] = '8';
out->dev_name[6] = 'L';
out->dev_name[7] = 'C';
- out->dev_name[8] = '1';
- out->dev_name[9] = '2';
- out->dev_name[10] = '8';
- out->dev_name[11] = '0';
- out->dev_name[12] = '\0';
+
+ switch(cfg->total_x) {
+ default:
+ /* default to 1280 if user gave some odd resolution */
+ out->dev_name[8] = '1';
+ out->dev_name[9] = '2';
+ out->dev_name[10] = '8';
+ out->dev_name[11] = '0';
+ out->dev_name[12] = '\0';
+ break;
+
+ case 1024:
+ out->dev_name[8] = '1';
+ out->dev_name[9] = '0';
+ out->dev_name[10] = '2';
+ out->dev_name[11] = '4';
+ out->dev_name[12] = '\0';
+ break;
+
+ case 800:
+ out->dev_name[8] = '8';
+ out->dev_name[9] = '0';
+ out->dev_name[10] = '0';
+ out->dev_name[11] = '\0';
+ break;
+
+ case 640:
+ out->dev_name[8] = '6';
+ out->dev_name[9] = '4';
+ out->dev_name[10] = '0';
+ out->dev_name[11] = '\0';
+ break;
+
+ }
return 0;
}