2004-04-04 Yoshinori K. Okuji <okuji@enbug.org>

All symbols prefixed with PUPA_ and pupa_ are renamed to GRUB_
	and grub_, respectively. Because the conversion is trivial and
	mechanical, I omit the details here. Please refer to the CVS
	if you need more information.
This commit is contained in:
okuji 2004-04-04 13:46:03 +00:00
parent 6a1425510d
commit 4b13b216f4
125 changed files with 6198 additions and 6181 deletions

View file

@ -1,6 +1,6 @@
/* ofdisk.c - Open Firmware disk access. */
/*
* PUPA -- Preliminary Universal Programming Architecture for GRUB
* GRUB -- GRand Unified Bootloader
* Copyright (C) 2004 Free Software Foundation, Inc.
*
* This program is free software; you can redistribute it and/or modify
@ -18,70 +18,70 @@
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include <pupa/misc.h>
#include <pupa/disk.h>
#include <pupa/mm.h>
#include <pupa/machine/ieee1275.h>
#include <grub/misc.h>
#include <grub/disk.h>
#include <grub/mm.h>
#include <grub/machine/ieee1275.h>
static int
pupa_ofdisk_iterate (int (*hook) (const char *name))
grub_ofdisk_iterate (int (*hook) (const char *name))
{
int dev_iterate (struct pupa_ieee1275_devalias *alias)
int dev_iterate (struct grub_ieee1275_devalias *alias)
{
if (! pupa_strcmp (alias->type, "block"))
if (! grub_strcmp (alias->type, "block"))
hook (alias->name);
return 0;
}
pupa_devalias_iterate (dev_iterate);
grub_devalias_iterate (dev_iterate);
return 0;
}
static pupa_err_t
pupa_ofdisk_open (const char *name, pupa_disk_t disk)
static grub_err_t
grub_ofdisk_open (const char *name, grub_disk_t disk)
{
pupa_ieee1275_phandle_t devalias;
pupa_ieee1275_phandle_t dev;
pupa_ieee1275_ihandle_t dev_ihandle = 0;
grub_ieee1275_phandle_t devalias;
grub_ieee1275_phandle_t dev;
grub_ieee1275_ihandle_t dev_ihandle = 0;
char *devpath = 0;
/* XXX: This should be large enough for any possible case. */
char prop[64];
pupa_size_t pathlen;
grub_size_t pathlen;
int actual;
if (pupa_ieee1275_finddevice ("/aliases", &devalias))
return pupa_error (PUPA_ERR_UNKNOWN_DEVICE, "Can't read the aliases");
if (grub_ieee1275_finddevice ("/aliases", &devalias))
return grub_error (GRUB_ERR_UNKNOWN_DEVICE, "Can't read the aliases");
pupa_ieee1275_get_property_length (devalias, name, &pathlen);
devpath = pupa_malloc (pathlen);
grub_ieee1275_get_property_length (devalias, name, &pathlen);
devpath = grub_malloc (pathlen);
if (! devpath)
return pupa_errno;
return grub_errno;
if (pupa_ieee1275_get_property (devalias, name, devpath, pathlen, &actual))
return pupa_error (PUPA_ERR_UNKNOWN_DEVICE, "No such device alias");
if (grub_ieee1275_get_property (devalias, name, devpath, pathlen, &actual))
return grub_error (GRUB_ERR_UNKNOWN_DEVICE, "No such device alias");
/* To access the complete disk add `:0'. */
pupa_strcat (devpath, ":0");
pupa_ieee1275_open (devpath, &dev_ihandle);
grub_strcat (devpath, ":0");
grub_ieee1275_open (devpath, &dev_ihandle);
if (! dev_ihandle)
return pupa_error (PUPA_ERR_UNKNOWN_DEVICE, "Can't open device");
return grub_error (GRUB_ERR_UNKNOWN_DEVICE, "Can't open device");
if (pupa_ieee1275_finddevice (devpath, &dev))
if (grub_ieee1275_finddevice (devpath, &dev))
{
pupa_error (PUPA_ERR_UNKNOWN_DEVICE, "Can't read device properties");
grub_error (GRUB_ERR_UNKNOWN_DEVICE, "Can't read device properties");
goto fail;
}
if (pupa_ieee1275_get_property (dev, "device_type", prop, sizeof (prop),
if (grub_ieee1275_get_property (dev, "device_type", prop, sizeof (prop),
&actual))
{
pupa_error (PUPA_ERR_BAD_DEVICE, "Can't read the device type");
grub_error (GRUB_ERR_BAD_DEVICE, "Can't read the device type");
goto fail;
}
if (pupa_strcmp (prop, "block"))
if (grub_strcmp (prop, "block"))
{
pupa_error (PUPA_ERR_BAD_DEVICE, "Not a block device");
grub_error (GRUB_ERR_BAD_DEVICE, "Not a block device");
goto fail;
}
@ -99,20 +99,20 @@ pupa_ofdisk_open (const char *name, pupa_disk_t disk)
disk->data = (void *) dev_ihandle;
fail:
if (pupa_errno)
pupa_ieee1275_close (dev_ihandle);
pupa_free (devpath);
return pupa_errno;
if (grub_errno)
grub_ieee1275_close (dev_ihandle);
grub_free (devpath);
return grub_errno;
}
static void
pupa_ofdisk_close (pupa_disk_t disk)
grub_ofdisk_close (grub_disk_t disk)
{
pupa_ieee1275_close ((pupa_ieee1275_ihandle_t) disk->data);
grub_ieee1275_close ((grub_ieee1275_ihandle_t) disk->data);
}
static pupa_err_t
pupa_ofdisk_read (pupa_disk_t disk, unsigned long sector,
static grub_err_t
grub_ofdisk_read (grub_disk_t disk, unsigned long sector,
unsigned long size, char *buf)
{
int status;
@ -121,41 +121,41 @@ pupa_ofdisk_read (pupa_disk_t disk, unsigned long sector,
pos = (unsigned long long) sector * 512UL;
pupa_ieee1275_seek ((pupa_ieee1275_ihandle_t) disk->data, (int) (pos >> 32),
grub_ieee1275_seek ((grub_ieee1275_ihandle_t) disk->data, (int) (pos >> 32),
(int) pos & 0xFFFFFFFFUL, &status);
if (status != 0)
return pupa_error (PUPA_ERR_READ_ERROR,
return grub_error (GRUB_ERR_READ_ERROR,
"Seek error, can't seek block %d", sector);
pupa_ieee1275_read ((pupa_ieee1275_ihandle_t) disk->data, buf,
grub_ieee1275_read ((grub_ieee1275_ihandle_t) disk->data, buf,
size * 512UL, &actual);
if (actual != actual)
return pupa_error (PUPA_ERR_READ_ERROR, "Read error on block: %d", sector);
return grub_error (GRUB_ERR_READ_ERROR, "Read error on block: %d", sector);
return 0;
}
static pupa_err_t
pupa_ofdisk_write (pupa_disk_t disk __attribute ((unused)),
static grub_err_t
grub_ofdisk_write (grub_disk_t disk __attribute ((unused)),
unsigned long sector __attribute ((unused)),
unsigned long size __attribute ((unused)),
const char *buf __attribute ((unused)))
{
return PUPA_ERR_NOT_IMPLEMENTED_YET;
return GRUB_ERR_NOT_IMPLEMENTED_YET;
}
static struct pupa_disk_dev pupa_ofdisk_dev =
static struct grub_disk_dev grub_ofdisk_dev =
{
.name = "ofdisk",
.iterate = pupa_ofdisk_iterate,
.open = pupa_ofdisk_open,
.close = pupa_ofdisk_close,
.read = pupa_ofdisk_read,
.write = pupa_ofdisk_write,
.iterate = grub_ofdisk_iterate,
.open = grub_ofdisk_open,
.close = grub_ofdisk_close,
.read = grub_ofdisk_read,
.write = grub_ofdisk_write,
.next = 0
};
void
pupa_ofdisk_init (void)
grub_ofdisk_init (void)
{
pupa_disk_dev_register (&pupa_ofdisk_dev);
grub_disk_dev_register (&grub_ofdisk_dev);
}

View file

@ -1,6 +1,6 @@
/* partiton.c - Read macintosh partition tables. */
/*
* PUPA -- Preliminary Universal Programming Architecture for GRUB
* GRUB -- GRand Unified Bootloader
* Copyright (C) 2004 Free Software Foundation, Inc.
*
* This program is free software; you can redistribute it and/or modify
@ -18,20 +18,20 @@
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include <pupa/disk.h>
#include <pupa/misc.h>
#include <pupa/mm.h>
#include <pupa/machine/partition.h>
#include <grub/disk.h>
#include <grub/misc.h>
#include <grub/mm.h>
#include <grub/machine/partition.h>
pupa_err_t
pupa_partition_iterate (pupa_disk_t disk,
int (*hook) (const pupa_partition_t partition))
grub_err_t
grub_partition_iterate (grub_disk_t disk,
int (*hook) (const grub_partition_t partition))
{
struct pupa_partition part;
struct pupa_apple_part apart;
struct pupa_disk raw;
struct grub_partition part;
struct grub_apple_part apart;
struct grub_disk raw;
int partno = 0;
int pos = PUPA_DISK_SECTOR_SIZE * 2;
int pos = GRUB_DISK_SECTOR_SIZE * 2;
/* Enforce raw disk access. */
raw = *disk;
@ -39,12 +39,12 @@ pupa_partition_iterate (pupa_disk_t disk,
for (;;)
{
if (pupa_disk_read (&raw, pos / PUPA_DISK_SECTOR_SIZE,
pos % PUPA_DISK_SECTOR_SIZE,
sizeof (struct pupa_apple_part), (char *) &apart))
return pupa_errno;
if (grub_disk_read (&raw, pos / GRUB_DISK_SECTOR_SIZE,
pos % GRUB_DISK_SECTOR_SIZE,
sizeof (struct grub_apple_part), (char *) &apart))
return grub_errno;
if (apart.magic != PUPA_APPLE_PART_MAGIC)
if (apart.magic != GRUB_APPLE_PART_MAGIC)
break;
part.start = apart.first_phys_block;
@ -53,34 +53,34 @@ pupa_partition_iterate (pupa_disk_t disk,
part.index = partno;
if (hook (&part))
return pupa_errno;
return grub_errno;
if (apart.first_phys_block == PUPA_DISK_SECTOR_SIZE * 2)
if (apart.first_phys_block == GRUB_DISK_SECTOR_SIZE * 2)
return 0;
pos += sizeof (struct pupa_apple_part);
pos += sizeof (struct grub_apple_part);
partno++;
}
return 0;
}
pupa_partition_t
pupa_partition_probe (pupa_disk_t disk, const char *str)
grub_partition_t
grub_partition_probe (grub_disk_t disk, const char *str)
{
pupa_partition_t p;
grub_partition_t p;
int partnum = 0;
char *s = (char *) str;
int find_func (const pupa_partition_t partition)
int find_func (const grub_partition_t partition)
{
if (partnum == partition->index)
{
p = (pupa_partition_t) pupa_malloc (sizeof (*p));
p = (grub_partition_t) grub_malloc (sizeof (*p));
if (! p)
return 1;
pupa_memcpy (p, partition, sizeof (*p));
grub_memcpy (p, partition, sizeof (*p));
return 1;
}
@ -88,33 +88,33 @@ pupa_partition_probe (pupa_disk_t disk, const char *str)
}
/* Get the partition number. */
partnum = pupa_strtoul (s, &s, 0);
if (pupa_errno)
partnum = grub_strtoul (s, &s, 0);
if (grub_errno)
{
pupa_error (PUPA_ERR_BAD_FILENAME, "invalid partition");
grub_error (GRUB_ERR_BAD_FILENAME, "invalid partition");
return 0;
}
if (pupa_partition_iterate (disk, find_func))
if (grub_partition_iterate (disk, find_func))
goto fail;
return p;
fail:
pupa_free (p);
grub_free (p);
return 0;
}
char *
pupa_partition_get_name (const pupa_partition_t p)
grub_partition_get_name (const grub_partition_t p)
{
char *name;
name = pupa_malloc (13);
name = grub_malloc (13);
if (! name)
return 0;
pupa_sprintf (name, "%d", p->index);
grub_sprintf (name, "%d", p->index);
return name;
}