File: [local] / sys / arch / hppa / stand / libsa / dk.c (download)
Revision 1.1.1.1 (vendor branch), Tue Mar 4 16:05:44 2008 UTC (16 years, 6 months ago) by nbrk
Branch: OPENBSD_4_2_BASE, MAIN
CVS Tags: jornada-partial-support-wip, HEAD Changes since 1.1: +0 -0 lines
Import of OpenBSD 4.2 release kernel tree with initial code to support
Jornada 720/728, StrongARM 1110-based handheld PC.
At this point kernel roots on NFS and boots into vfs_mountroot() and traps.
What is supported:
- glass console, Jornada framebuffer (jfb) works in 16bpp direct color mode
(needs some palette tweaks for non black/white/blue colors, i think)
- saic, SA11x0 interrupt controller (needs cleanup)
- sacom, SA11x0 UART (supported only as boot console for now)
- SA11x0 GPIO controller fully supported (but can't handle multiple interrupt
handlers on one gpio pin)
- sassp, SSP port on SA11x0 that attaches spibus
- Jornada microcontroller (jmcu) to control kbd, battery, etc throught
the SPI bus (wskbd attaches on jmcu, but not tested)
- tod functions seem work
- initial code for SA-1111 (chip companion) : this is TODO
Next important steps, i think:
- gpio and intc on sa1111
- pcmcia support for sa11x0 (and sa1111 help logic)
- REAL root on nfs when we have PCMCIA support (we may use any of supported pccard NICs)
- root on wd0! (using already supported PCMCIA-ATA)
|
/* $OpenBSD: dk.c,v 1.13 2004/11/22 18:41:41 mickey Exp $ */
/*
* Copyright 1996 1995 by Open Software Foundation, Inc.
* All Rights Reserved
*
* Permission to use, copy, modify, and distribute this software and
* its documentation for any purpose and without fee is hereby granted,
* provided that the above copyright notice appears in all copies and
* that both the copyright notice and this permission notice appear in
* supporting documentation.
*
* OSF DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE.
*
* IN NO EVENT SHALL OSF BE LIABLE FOR ANY SPECIAL, INDIRECT, OR
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
* LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT,
* NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
*/
#include "libsa.h"
#include <sys/param.h>
#include <sys/disklabel.h>
#include <sys/reboot.h>
#include <machine/pdc.h>
#include <machine/iomod.h>
#include "dev_hppa.h"
const char *
dk_disklabel(struct hppa_dev *dp, struct disklabel *label)
{
char buf[DEV_BSIZE];
size_t ret;
if (iodcstrategy(dp, F_READ, LABELSECTOR, DEV_BSIZE, buf, &ret))
if (ret != DEV_BSIZE)
return "cannot read disklabel";
return (getdisklabel(buf, label));
}
int
dkopen(struct open_file *f, ...)
{
struct disklabel *lp;
struct hppa_dev *dp = f->f_devdata;
const char *st;
#ifdef DEBUG
if (debug)
printf("dkopen(%p)\n", f);
#endif
if (!(dp->pz_dev = pdc_findev(-1, PCL_RANDOM)))
return ENXIO;
lp = dp->label;
st = NULL;
#ifdef DEBUG
if (debug)
printf ("disklabel\n");
#endif
if ((st = dk_disklabel(dp, lp)) != NULL) {
#ifdef DEBUG
if (debug)
printf ("dkopen: %s\n", st);
#endif
/* we do not know if it's a disk or net, but do not fail */
} else {
u_int i;
i = B_PARTITION(dp->bootdev);
if (i >= lp->d_npartitions || !lp->d_partitions[i].p_size)
return (EPART);
dp->fsoff = lp->d_partitions[i].p_offset;
}
#ifdef DEBUGBUG
if (debug)
printf ("dkopen() ret\n");
#endif
return (0);
}
int
dkclose(f)
struct open_file *f;
{
free (f->f_devdata, sizeof(struct hppa_dev));
f->f_devdata = NULL;
return 0;
}