diff options
Diffstat (limited to 'perl-install/c/stuff.xs.pl')
| -rwxr-xr-x[-rw-r--r--] | perl-install/c/stuff.xs.pl | 834 | 
1 files changed, 556 insertions, 278 deletions
| diff --git a/perl-install/c/stuff.xs.pl b/perl-install/c/stuff.xs.pl index 60eb94b92..1a148b497 100644..100755 --- a/perl-install/c/stuff.xs.pl +++ b/perl-install/c/stuff.xs.pl @@ -5,11 +5,9 @@ print '  #include "perl.h"  #include "XSUB.h" -/* workaround for glibc and kernel header files not in sync */ -#define dev_t dev_t -  #include <ctype.h>  #include <stdlib.h> +#include <stdio.h>  #include <unistd.h>  #include <syslog.h>  #include <fcntl.h> @@ -22,6 +20,9 @@ print '  #include <sys/stat.h>  #include <sys/utsname.h>  #include <sys/mount.h> +#undef __USE_MISC +#include <linux/if.h> +#include <linux/wireless.h>  #include <linux/keyboard.h>  #include <linux/kd.h>  #include <linux/hdreg.h> @@ -30,144 +31,144 @@ print '  #include <linux/cdrom.h>  #include <linux/loop.h>  #include <linux/blkpg.h> +#include <linux/iso_fs.h>  #include <net/if.h>  #include <net/route.h> +#include <netinet/in.h> +#include <linux/sockios.h> +#include <linux/ethtool.h> +#include <linux/input.h> +#include <execinfo.h> -/* for is_ext3 */ -#include <ext2fs/ext2_fs.h> -#include <ext2fs/ext2fs.h> +// for UPS on USB: +# define HID_MAX_USAGES 1024 +#include <linux/hiddev.h>  #include <libldetect.h> -#include <X11/Xlib.h> -#include <X11/extensions/xf86misc.h> -#include <langinfo.h>  #include <string.h> -#include <iconv.h> - -#include <libintl.h> -#include <term.h> -#undef max_colors  #define SECTORSIZE 512 -char *prom_getopt(); -void prom_setopt(); -char *prom_getproperty(); -char *disk2PromPath(); -char *promRootName(); - +#include <parted/parted.h>  '; -$ENV{C_DRAKX} && $Config{archname} =~ /i.86/ and print ' +$Config{archname} =~ /i.86/ and print '  char *pcmcia_probe(void);  '; -$ENV{C_RPM} and print ' -#undef Fflush -#undef Mkdir -#undef Stat -#include <rpm/rpmlib.h> -#include <rpm/rpmio.h> +print ' -void rpmError_callback_empty(void) {} +/* log_message and log_perror are used in stage1 pcmcia probe */ +void log_message(const char * s, ...) { +   va_list args; +   va_list args_copy; +   FILE * logtty = fopen("/dev/tty3", "w"); +   if (!logtty) +      return; +   fprintf(logtty, "* "); +   va_start(args, s); +   vfprintf(logtty, s, args); +   fprintf(logtty, "\n"); +   fclose(logtty); +   va_end(args); + +   logtty = fopen("/tmp/ddebug.log", "a"); +   if (!logtty) +      return; +   fprintf(logtty, "* "); +   va_copy(args_copy, args); +   va_start(args_copy, s); +   vfprintf(logtty, s, args_copy); +   fprintf(logtty, "\n"); +   fclose(logtty); +   va_end(args_copy); +} +void log_perror(const char *msg) { +   log_message("%s: %s", msg, strerror(errno)); +} -int rpmError_callback_data; -void rpmError_callback(void) { -  if (rpmErrorCode() != RPMERR_UNLINK && rpmErrorCode() != RPMERR_RMDIR) { -    write(rpmError_callback_data, rpmErrorString(), strlen(rpmErrorString())); -  } +HV* common_pciusb_hash_init(struct pciusb_entry *e) { +   HV *rh = (HV *)sv_2mortal((SV *)newHV());  +   hv_store(rh, "vendor",         6, newSViv(e->vendor),     0); +   hv_store(rh, "subvendor",      9, newSViv(e->subvendor),  0); +   hv_store(rh, "id",             2, newSViv(e->device),     0); +   hv_store(rh, "subid",          5, newSViv(e->subdevice),  0); +   hv_store(rh, "driver",         6, newSVpv(e->module ? e->module : "unknown", 0), 0); +   hv_store(rh, "description",   11, newSVpv(e->text, 0),    0);  +   hv_store(rh, "pci_bus",        7, newSViv(e->pci_bus),    0); +   hv_store(rh, "pci_device",    10, newSViv(e->pci_device), 0); +   return rh;  }  '; -$ENV{C_DRAKX} and print ' - -#include <gdk/gdkx.h> - -void initIMPS2() { -  unsigned char imps2_s1[] = { 243, 200, 243, 100, 243, 80, }; -  unsigned char imps2_s2[] = { 246, 230, 244, 243, 100, 232, 3, }; - -  int fd = open("/dev/mouse", O_WRONLY); -  if (fd < 0) return; +print ' -  write (fd, imps2_s1, sizeof (imps2_s1)); -  usleep (30000); -  write (fd, imps2_s2, sizeof (imps2_s2)); -  usleep (30000); -  tcflush (fd, TCIFLUSH); -  tcdrain(fd); +int length_of_space_padded(char *str, int len) { +  while (len >= 0 && str[len-1] == \' \') +    --len; +  return len;  } -void log_message(const char * s, ...) {} - -'; +PedPartitionFlag string_to_pedpartflag(char*type) { +   PedPartitionFlag flag = 0; +   if (!strcmp(type, "ESP")) { +      flag = PED_PARTITION_ESP; +   } else if (!strcmp(type, "BIOS_GRUB")) { +      flag = PED_PARTITION_BIOS_GRUB; +   } else if (!strcmp(type, "LVM")) { +      flag = PED_PARTITION_LVM; +   } else if (!strcmp(type, "RAID")) { +      flag = PED_PARTITION_RAID; +   } else { +      printf("set_partition_flag: unknown type: %s\n", type); +   } +   return flag; +} -print ' +int is_recovery_partition(PedPartition*part) { +  /* FIXME: not sure everything is covered ... */ +  return ped_partition_get_flag(part, PED_PARTITION_HPSERVICE) // HP-UX service partition +      || ped_partition_get_flag(part, PED_PARTITION_MSFT_RESERVED) // Microsoft Reserved Partition -> LDM metadata, ... +      || ped_partition_get_flag(part, PED_PARTITION_DIAG) // ==> PARTITION_MSFT_RECOVERY (Windows Recovery Environment) +      || ped_partition_get_flag(part, PED_PARTITION_APPLE_TV_RECOVERY) +      || ped_partition_get_flag(part, PED_PARTITION_HIDDEN); +}  MODULE = c::stuff		PACKAGE = c::stuff  '; -$ENV{C_DRAKX} && $Config{archname} =~ /i.86/ and print ' +$Config{archname} =~ /i.86/ and print '  char *  pcmcia_probe()  '; -$ENV{C_DRAKX} and print ' - +print '  int -Xtest(display) -  char *display +del_partition(hd, part_number) +  int hd +  int part_number    CODE: -  int pid; -  if ((pid = fork()) == 0) { -    Display *d = XOpenDisplay(display); -    if (d) { -      XSetCloseDownMode(d, RetainPermanent); -      XCloseDisplay(d); -    } -    _exit(d != NULL); +  { +    struct blkpg_partition p = { 0, 0, part_number, "", "" }; +    struct blkpg_ioctl_arg s = { BLKPG_DEL_PARTITION, 0, sizeof(struct blkpg_partition), (void *) &p }; +    RETVAL = ioctl(hd, BLKPG, &s) == 0;    } -  waitpid(pid, &RETVAL, 0);    OUTPUT:    RETVAL -void -setMouseLive(display, type, emulate3buttons) -  char *display -  int type -  int emulate3buttons -  CODE: -  { -    XF86MiscMouseSettings mseinfo; -    Display *d = XOpenDisplay(display); -    if (d) { -      if (XF86MiscGetMouseSettings(d, &mseinfo) == True) { -        mseinfo.type = type; -        mseinfo.flags |= MF_REOPEN; -        mseinfo.emulate3buttons = emulate3buttons; -        XF86MiscSetMouseSettings(d, &mseinfo); -        XFlush(d); -        if (type == MTYPE_IMPS2) initIMPS2(); -      } -    } -  } -'; - -print ' -  int -add_partition(hd, start_sector, size_sector, part_number) +add_partition(hd, part_number, start_sector, size_sector)    int hd +  int part_number    unsigned long start_sector    unsigned long size_sector -  int part_number    CODE:    { -    long long start = start_sector * 512; -    long long size = size_sector * 512; +    long long start = (long long) start_sector * 512; +    long long size = (long long) size_sector * 512;      struct blkpg_partition p = { start, size, part_number, "", "" };      struct blkpg_ioctl_arg s = { BLKPG_ADD_PARTITION, 0, sizeof(struct blkpg_partition), (void *) &p };      RETVAL = ioctl(hd, BLKPG, &s) == 0; @@ -188,51 +189,21 @@ is_secure_file(filename)    OUTPUT:    RETVAL -int -is_ext3(device_name) -  char * device_name -  CODE: -  { -    ext2_filsys fs; -    int retval = ext2fs_open (device_name, 0, 0, 0, unix_io_manager, &fs); -    if (retval) { -      RETVAL = 0; -    } else { -      RETVAL = fs->super->s_feature_compat & EXT3_FEATURE_COMPAT_HAS_JOURNAL; -      ext2fs_close(fs);   -    } -  } -  OUTPUT: -  RETVAL -  void -setlocale() +init_setlocale()     CODE:     setlocale(LC_ALL, "");     setlocale(LC_NUMERIC, "C"); /* otherwise eval "1.5" returns 1 in fr_FR for example */  char * -bindtextdomain(domainname, dirname) -   char * domainname -   char * dirname - -char * -dgettext(domainname, msgid) -   char * domainname -   char * msgid - -int -KTYP(x) -  int x -  CODE: -  RETVAL = KTYP(x); -  OUTPUT: -  RETVAL +setlocale(category, locale = NULL) +    int     category +    char *      locale  int  lseek_sector(fd, sector, offset)    int fd -  long sector +  unsigned long sector    long offset    CODE:    RETVAL = lseek64(fd, (off64_t) sector * SECTORSIZE + offset, SEEK_SET) >= 0; @@ -263,39 +234,25 @@ floppy_info(name)    RETVAL = NULL;    if (fd != -1) {       char drivtyp[17]; -     ioctl(fd, FDGETDRVTYP, (void *)drivtyp); -     RETVAL = drivtyp; +     if (ioctl(fd, FDGETDRVTYP, (void *)drivtyp) == 0) { +       struct floppy_drive_struct ds; +       if (ioctl(fd, FDPOLLDRVSTAT, &ds) == 0 && ds.track >= 0) +         RETVAL = drivtyp; +     }       close(fd);    }    OUTPUT:    RETVAL -unsigned int +NV  total_sectors(fd)    int fd    CODE:    { -    long s; -    RETVAL = ioctl(fd, BLKGETSIZE, &s) == 0 ? s : 0; -  } -  OUTPUT: -  RETVAL - -void -unlimit_core() -  CODE: -  { -    struct rlimit rlim = { RLIM_INFINITY, RLIM_INFINITY }; -    setrlimit(RLIMIT_CORE, &rlim); -  } - -int -getlimit_core() -  CODE: -  { -    struct rlimit rlim; -    getrlimit(RLIMIT_CORE, &rlim); -    RETVAL = rlim.rlim_cur; +    unsigned long long ll; +    unsigned long l; +    RETVAL = ioctl(fd, BLKGETSIZE64, &ll) == 0 ? ll / 512 :  +             ioctl(fd, BLKGETSIZE, &l) == 0 ? l : 0;    }    OUTPUT:    RETVAL @@ -314,7 +271,7 @@ syslog(priority, mesg)    int priority    char *mesg    CODE: -  syslog(priority, mesg); +  syslog(priority, "%s", mesg);  void  setsid() @@ -322,25 +279,48 @@ setsid()  void  _exit(status)    int status -   -int -detectSMP()  void -pci_probe(probe_type) -  int probe_type +usleep(microseconds) +  unsigned long microseconds + + +char* +get_pci_description(int vendor_id,int device_id) + +void +hid_probe()    PPCODE: -    struct pciusb_entries entries = pci_probe(probe_type); -    char buf[2048]; +    struct hid_entries entries = hid_probe(); +    int i; + +    EXTEND(SP, entries.nb); +    for (i = 0; i < entries.nb; i++) { +      struct hid_entry *e = &entries.entries[i]; +      HV *rh = (HV *)sv_2mortal((SV *)newHV()); +      hv_store(rh, "description", 11, newSVpv(e->text, 0),   0); +      hv_store(rh, "driver",       6, newSVpv(e->module, 0), 0); +      PUSHs(newRV((SV *)rh)); +    } +    hid_entries_free(&entries); + +void +pci_probe() +  PPCODE: +    struct pciusb_entries entries = pci_probe();      int i;      EXTEND(SP, entries.nb);      for (i = 0; i < entries.nb; i++) {        struct pciusb_entry *e = &entries.entries[i]; -      snprintf(buf, sizeof(buf), "%04x\t%04x\t%04x\t%04x\t%d\t%d\t%d\t%s\t%s\t%s",  -               e->vendor, e->device, e->subvendor, e->subdevice, e->pci_bus, e->pci_device, e->pci_function, -               pci_class2text(e->class_), e->module ? e->module : "unknown", e->text); -      PUSHs(sv_2mortal(newSVpv(buf, 0))); +      HV * rh = common_pciusb_hash_init(e); +      hv_store(rh, "pci_domain",    10, newSViv(e->pci_domain),      0); +      hv_store(rh, "pci_function",  12, newSViv(e->pci_function),    0); +      hv_store(rh, "pci_revision",  12, newSViv(e->pci_revision),    0); +      hv_store(rh, "is_pciexpress", 13, newSViv(e->is_pciexpress),   0); +      hv_store(rh, "nice_media_type", 15, newSVpv(e->class, 0),      0); +      hv_store(rh, "media_type",    10, newSVpv(pci_class2text(e->class_id), 0), 0);  +      PUSHs(newRV((SV *)rh));      }      pciusb_free(&entries); @@ -354,30 +334,138 @@ usb_probe()      EXTEND(SP, entries.nb);      for (i = 0; i < entries.nb; i++) {        struct pciusb_entry *e = &entries.entries[i]; -      snprintf(buf, sizeof(buf), "%04x\t%04x\t%s\t%s\t%s\t%d\t%d",  -               e->vendor, e->device, usb_class2text(e->class_), e->module ? e->module : "unknown", e->text, e->pci_bus, e->pci_device); -      PUSHs(sv_2mortal(newSVpv(buf, 0))); +      struct usb_class_text class_text = usb_class2text(e->class_id); +      snprintf(buf, sizeof(buf), "%s|%s|%s", class_text.usb_class_text, class_text.usb_sub_text, class_text.usb_prot_text); +      HV * rh = common_pciusb_hash_init(e); +      hv_store(rh, "usb_port",       8, newSViv(e->usb_port),   0); +      hv_store(rh, "media_type",    10, newSVpv(buf, 0),        0); +      PUSHs(newRV((SV *)rh));      }      pciusb_free(&entries); +void +dmi_probe() +  PPCODE: +    //dmidecode_file = "/usr/share/ldetect-lst/dmidecode.Laptop.Dell-Latitude-C810"; +    //dmidecode_file = "../../soft/ldetect-lst/test/dmidecode.Laptop.Sony-Vaio-GRX316MP"; + +    struct dmi_entries entries = dmi_probe(); +    int i; + +    EXTEND(SP, entries.nb); +    for (i = 0; i < entries.nb; i++) { +      HV * rh = (HV *)sv_2mortal((SV *)newHV());  +      hv_store(rh, "driver",       6, newSVpv(entries.entries[i].module, 0),     0);  +      hv_store(rh, "description", 11, newSVpv(entries.entries[i].constraints, 0),  0);  +      PUSHs(newRV((SV *)rh)); +    } +    dmi_entries_free(entries); + +  unsigned int  getpagesize() + +char* +get_usb_ups_name(int fd) +  CODE: +        /* from nut/drivers/hidups.c::upsdrv_initups() : */ +        char name[256]; +        ioctl(fd, HIDIOCGNAME(sizeof(name)), name); +        RETVAL=name; +        ioctl(fd, HIDIOCINITREPORT, 0); +  OUTPUT: +  RETVAL + + +int +res_init() +  int -hasNetDevice(device) +isNetDeviceWirelessAware(device)    char * device    CODE: -    struct ifreq req; +    struct iwreq ifr; +      int s = socket(AF_INET, SOCK_DGRAM, 0); -    if (s == -1) { RETVAL = 0; return; } -    strcpy(req.ifr_name, device); +    memset(&ifr, 0, sizeof(ifr)); +    strncpy(ifr.ifr_name, device, IFNAMSIZ); +    RETVAL = ioctl(s, SIOCGIWNAME, &ifr) != -1; +    close(s); +  OUTPUT: +  RETVAL + + +void +get_netdevices() +  PPCODE: +     struct ifconf ifc; +     struct ifreq *ifr; +     int i; +     int numreqs = 10; + +     int s = socket(AF_INET, SOCK_DGRAM, 0); + +     ifc.ifc_buf = NULL; +     for (;;) { +          ifc.ifc_len = sizeof(struct ifreq) * numreqs; +          ifc.ifc_buf = realloc(ifc.ifc_buf, ifc.ifc_len); + +          if (ioctl(s, SIOCGIFCONF, &ifc) < 0) { +               perror("SIOCGIFCONF"); +               close(s); +               return; +          } +          if (ifc.ifc_len == sizeof(struct ifreq) * numreqs) { +               /* assume it overflowed and try again */ +               numreqs += 10;                                                                          +               continue;                                                                               +          } +          break; +     } +     if (ifc.ifc_len) { +          ifr = ifc.ifc_req; +          EXTEND(sp, ifc.ifc_len); +          for (i=0; i < ifc.ifc_len; i+= sizeof(struct ifreq)) { +               PUSHs(sv_2mortal(newSVpv(ifr->ifr_name, 0))); +               ifr++; +          } +     } + +     close(s); + + +char* +getNetDriver(char* device) +  ALIAS: +    getHwIDs = 1 +  CODE: +    struct ifreq ifr; +    struct ethtool_drvinfo drvinfo; +    int s = socket(AF_INET, SOCK_DGRAM, 0); -    RETVAL = ioctl(s, SIOCGIFFLAGS, &req) == 0; +    memset(&ifr, 0, sizeof(ifr)); +    strncpy(ifr.ifr_name, device, IFNAMSIZ); + +    drvinfo.cmd = ETHTOOL_GDRVINFO; +    ifr.ifr_data = (caddr_t) &drvinfo; + +    if (ioctl(s, SIOCETHTOOL, &ifr) != -1) { +        switch (ix) { +            case 0: +                RETVAL = strdup(drvinfo.driver); +                break; +            case 1: +                RETVAL = strdup(drvinfo.bus_info); +                break; +        } +    } else { perror("SIOCETHTOOL"); RETVAL = strdup(""); }      close(s);    OUTPUT:    RETVAL +  int  addDefaultRoute(gateway)    char *gateway @@ -405,6 +493,90 @@ addDefaultRoute(gateway)    OUTPUT:    RETVAL + +char* +get_hw_address(const char* ifname) +  CODE: +    int s; +    struct ifreq ifr; +    unsigned char *a; +    char *res; +    s = socket(AF_INET, SOCK_DGRAM, IPPROTO_IP); +    if (s < 0) { +        perror("socket"); +        RETVAL = NULL; +        return; +    } +    strncpy((char*) &ifr.ifr_name, ifname, IFNAMSIZ); +    if (ioctl(s, SIOCGIFHWADDR, &ifr) < 0) { +        perror("ioctl(SIOCGIFHWADDR)"); +        RETVAL = NULL; +        return; +    } +    a = (unsigned char*)ifr.ifr_hwaddr.sa_data; +    asprintf(&res, "%02x:%02x:%02x:%02x:%02x:%02x", a[0],a[1],a[2],a[3],a[4],a[5]); +    RETVAL= res; +  OUTPUT: +  RETVAL + + +void +strftime(fmt, sec, min, hour, mday, mon, year, wday = -1, yday = -1, isdst = -1) +    char *      fmt +    int     sec +    int     min +    int     hour +    int     mday +    int     mon +    int     year +    int     wday +    int     yday +    int     isdst +    CODE: +    {    +        char *buf = my_strftime(fmt, sec, min, hour, mday, mon, year, wday, yday, isdst); +        if (buf) { +        ST(0) = sv_2mortal(newSVpv(buf, 0)); +        Safefree(buf); +        } +    } + +#define BITS_PER_LONG (sizeof(long) * 8) +#define NBITS(x) ((((x)-1)/BITS_PER_LONG)+1) +#define OFF(x)  ((x)%BITS_PER_LONG) +#define BIT(x)  (1UL<<OFF(x)) +#define LONG(x) ((x)/BITS_PER_LONG) +#define test_bit(bit, array)    ((array[LONG(bit)] >> OFF(bit)) & 1) + +void +EVIocGBitKey (char *file) +	PPCODE: +		int fd; +		int i; +		long bitmask[NBITS(KEY_MAX)]; + +		fd = open (file, O_RDONLY); +		if (fd < 0) { +			warn("Cannot open %s: %s\n", file, strerror(errno)); +			return; +		} + +		if (ioctl (fd, EVIOCGBIT(EV_KEY, sizeof (bitmask)), bitmask) < 0) { +			perror ("ioctl EVIOCGBIT failed"); +			close (fd); +			return; +		} + +		close (fd); +        	for (i = NBITS(KEY_MAX) - 1; i > 0; i--) +			if (bitmask[i]) +				break; + +		for (; i >= 0; i--) { +			EXTEND(sp, 1); +			PUSHs(sv_2mortal(newSViv(bitmask[i]))); +		} +  char *  kernel_version()    CODE: @@ -413,148 +585,250 @@ kernel_version()    OUTPUT:    RETVAL -int -prom_open() +void +set_tagged_utf8(s) +   SV *s +   CODE: +   SvUTF8_on(s);  void -prom_close() +get_iso_volume_ids(int fd) +  INIT: +  struct iso_primary_descriptor voldesc; +  PPCODE: +  lseek(fd, 16 * ISOFS_BLOCK_SIZE, SEEK_SET); +  if (read(fd, &voldesc, sizeof(struct iso_primary_descriptor)) == sizeof(struct iso_primary_descriptor)) { +    if (voldesc.type[0] == ISO_VD_PRIMARY && !strncmp(voldesc.id, ISO_STANDARD_ID, sizeof(voldesc.id))) { +      size_t vol_id_len = length_of_space_padded(voldesc.volume_id, sizeof(voldesc.volume_id)); +      size_t app_id_len = length_of_space_padded(voldesc.application_id, sizeof(voldesc.application_id)); +      XPUSHs(vol_id_len != -1 ? sv_2mortal(newSVpv(voldesc.volume_id, vol_id_len)) : newSVpvs("")); +      XPUSHs(app_id_len != -1 ? sv_2mortal(newSVpv(voldesc.application_id, app_id_len)) : newSVpvs("")); +    } +  } -int -prom_getsibling(node) -  int node +'; -int -prom_getchild(node) -  int node +print ' -void -prom_getopt(key) -  char *key -  PPCODE: -  int lenp = 0; -  char *value = NULL; -  value = prom_getopt(key, &lenp); -  EXTEND(sp, 1); -  if (value != NULL) { -    PUSHs(sv_2mortal(newSVpv(value, 0))); +TYPEMAP: <<HERE +PedDisk*              T_PTROBJ +HERE + + + +int +set_partition_flag(PedDisk *disk, int part_number, char * type) +  CODE: +  RETVAL = 0; +  PedPartition* part = ped_disk_get_partition(disk, part_number); +  if (!part) { +    printf("set_partition_flag: failed to find partition\n");    } else { -    PUSHs(&PL_sv_undef); +    PedPartitionFlag flag = string_to_pedpartflag(type); +    if (flag) { +      RETVAL = ped_partition_set_flag(part, flag, 1); +    }    } +  OUTPUT: +  RETVAL -void -prom_setopt(key, value) -  char *key -  char *value -void -prom_getproperty(key) -  char *key -  PPCODE: -  int lenp = 0; -  char *value = NULL; -  value = prom_getproperty(key, &lenp); -  EXTEND(sp, 1); -  if (value != NULL) { -    PUSHs(sv_2mortal(newSVpv(value, lenp))); -  } else { -    PUSHs(&PL_sv_undef); +const char * +get_disk_type(char * device_path) +  CODE: +  PedDevice *dev = ped_device_get(device_path); +  RETVAL = NULL; +  if(dev) { +    PedDiskType* type = ped_disk_probe(dev); +    if(type) { +      RETVAL = type->name; +    }     } +  OUTPUT: +  RETVAL  void -prom_getstring(key) -  char *key +get_disk_partitions(char * device_path)    PPCODE: -  int lenp = 0; -  char *value = NULL; -  value = prom_getproperty(key, &lenp); -  EXTEND(sp, 1); -  if (value != NULL) { -    PUSHs(sv_2mortal(newSVpv(value, 0))); -  } else { -    PUSHs(&PL_sv_undef); +  PedDevice *dev = ped_device_get(device_path); +  if(dev) { +    PedDisk* disk = ped_disk_new(dev); +    PedPartition *part = NULL, *first_part = NULL; +    int count = 1; +    if(!disk) +      return; +    first_part = part = ped_disk_next_partition(disk, NULL); +    while(part) { +      part = ped_disk_next_partition(disk, part); +      count++; +    } +    EXTEND(SP, count); +    part = first_part; +    while(part) { +      if(part->num == -1) { +	   part = ped_disk_next_partition(disk, part); +	   continue; +      } +      char *path = ped_partition_get_path(part); +      char *flag = ""; +      if (ped_partition_get_flag(part, PED_PARTITION_ESP)) { +        flag = "ESP"; +      } else if (ped_partition_get_flag(part, PED_PARTITION_BIOS_GRUB)) { +        flag = "BIOS_GRUB"; +      } else if (ped_partition_get_flag(part, PED_PARTITION_LVM)) { +        flag = "LVM"; +      } else if (ped_partition_get_flag(part, PED_PARTITION_RAID)) { +        flag = "RAID"; +      } else if (is_recovery_partition(part)) { +        flag = "RECOVERY"; +      } +      HV * rh = (HV *)sv_2mortal((SV *)newHV()); +      hv_store(rh, "part_number",    11, newSViv(part->num),      0); +      hv_store(rh, "real_device",    11, newSVpv(path, 0),        0); +      hv_store(rh, "start",           5, newSViv(part->geom.start), 0); +      hv_store(rh, "size",            4, newSViv(part->geom.length), 0); +      hv_store(rh, "pt_type",         7, newSViv(0xba),           0); +      hv_store(rh, "flag",            4, newSVpv(flag, 0),        0); +      free(path); +      if(part->fs_type) +        hv_store(rh, "fs_type",       7, newSVpv(part->fs_type->name, 0), 0); +      PUSHs(newRV((SV *)rh)); +      part = ped_disk_next_partition(disk, part); +    } +    ped_disk_destroy(disk);    } -int -prom_getbool(key) -  char *key - -void -initSilo() - -char * -disk2PromPath(disk) -  unsigned char *disk +PedDisk* +disk_open(char * device_path, const char * type_name = NULL) +  CODE: +  PedDevice *dev = ped_device_get(device_path); +  RETVAL = NULL; +  if(dev) { +    if(type_name) { +      PedDiskType* type = ped_disk_type_get(type_name); +      if(type) { +        RETVAL = ped_disk_new_fresh(dev, type); +      } +    } else { +      RETVAL = ped_disk_new(dev); +    } +  } +  OUTPUT: +  RETVAL  int -hasAliases() +disk_delete_all(PedDisk* disk) +  CODE: +  RETVAL = 0; +  if (ped_disk_delete_all(disk)) { +    RETVAL = 1; +  } +  OUTPUT: +  RETVAL -char * -promRootName() +int +disk_del_partition(PedDisk* disk, int part_number) +  CODE: +  RETVAL = 0; +  PedPartition* part = ped_disk_get_partition(disk, part_number); +  if(!part) { +    printf("disk_del_partition: failed to find partition\n"); +  } else { +    RETVAL = ped_disk_delete_partition(disk, part); +  } +  OUTPUT: +  RETVAL -void -setPromVars(linuxAlias, bootDevice) -  char *linuxAlias -  char *bootDevice +int +disk_add_partition(PedDisk* disk, double start, double length, const char * fs_type) +  CODE: +  RETVAL=0; +  PedGeometry* geom = ped_geometry_new(disk->dev, (long long)start, (long long)length); +  PedPartition* part = ped_partition_new (disk, PED_PARTITION_NORMAL, ped_file_system_type_get(fs_type), (long long)start, (long long)start+length-1); +  PedConstraint* constraint = ped_constraint_new_from_max(geom); +  if(!part) { +    printf("ped_partition_new failed\n"); +  } else { +    RETVAL = ped_disk_add_partition (disk, part, constraint); +  } +  ped_geometry_destroy(geom); +  ped_constraint_destroy(constraint); +  OUTPUT: +  RETVAL -char * -iconv(s, from_charset, to_charset) -  char *s -  char *from_charset -  char *to_charset +int +disk_commit(PedDisk *disk)    CODE: -  iconv_t cd = iconv_open(to_charset, from_charset); -  RETVAL = s; -  if (cd != (iconv_t) (-1)) { -      size_t s_len = strlen(RETVAL); -      char *buf = alloca(3 * s_len + 10); /* 10 for safety, it should not be needed */ -      { -	  char *ptr = buf; -	  size_t ptr_len = 3 * s_len + 10; -	  if ((iconv(cd, &s, &s_len, &ptr, &ptr_len)) != (size_t) (-1)) { -	      *ptr = 0; -	      RETVAL = buf; -	  } +  RETVAL = 0; +  /* As done in ped_disk_commit(), open the device here, so that the underlying +     file descriptor is not closed between the call to ped_disk_commit_to_dev() +     and the call to ped_disk_commit_to_os(). This avoids unwanted udev events. */ +  if (ped_device_open(disk->dev)) { +    if (ped_disk_commit_to_dev(disk)) { +      RETVAL = 1; +      if (ped_disk_commit_to_os(disk)) { +        RETVAL = 2;        } -      iconv_close(cd); +    } +    ped_device_close(disk->dev);    } +  ped_disk_destroy(disk);    OUTPUT:    RETVAL -char * -standard_charset() +int +tell_kernel_to_reread_partition_table(char * device_path)    CODE: -  RETVAL = nl_langinfo(CODESET); +  PedDevice *dev = ped_device_get(device_path); +  RETVAL=0; +  if(dev) { +    PedDisk* disk = ped_disk_new(dev); +    if (disk) { +      if (ped_disk_commit_to_os (disk)) +         RETVAL=1; +      ped_disk_destroy(disk); +    } +  }    OUTPUT:    RETVAL -'; - -$ENV{C_RPM} and print ' -char * -rpmErrorString() +#define BACKTRACE_DEPTH				20 +  -void -rpmSetVeryVerbose() +char* +C_backtrace()    CODE: -  rpmSetVerbosity(RPMMESS_DEBUG); +  static char buf[1024]; +  int nAddresses, i; +  unsigned long idx = 0; +  void * addresses[BACKTRACE_DEPTH]; +  char ** symbols = NULL; +  nAddresses = backtrace(addresses, BACKTRACE_DEPTH); +  symbols = backtrace_symbols(addresses, nAddresses); +  if (symbols == NULL) { +      idx += sprintf(buf+idx, "ERROR: Retrieving symbols failed.\n"); +  } else { +      /* dump stack trace */ +      for (i = 0; i < nAddresses; ++i) +          idx += sprintf(buf+idx, "%d: %s\n", i, symbols[i]); +  } +  RETVAL = strdup(buf); +  OUTPUT: +  RETVAL + + -void -rpmErrorSetCallback(fd) -  int fd -  CODE: -  rpmError_callback_data = fd; -  rpmErrorSetCallback(rpmError_callback); -int -rpmvercmp(char *a, char *b);  ';  @macros = ( -  [ qw(int S_IFCHR S_IFBLK S_IFIFO KDSKBENT KT_SPEC NR_KEYS MAX_NR_KEYMAPS BLKRRPART TIOCSCTTY -       HDIO_GETGEO BLKGETSIZE LOOP_GET_STATUS -       MS_MGC_VAL MS_RDONLY O_NONBLOCK F_SETFL F_GETFL O_CREAT SECTORSIZE WNOHANG -       VT_ACTIVATE VT_WAITACTIVE VT_GETSTATE CDROM_LOCKDOOR CDROMEJECT +  [ qw(int S_IFCHR S_IFBLK S_IFIFO S_IFMT KDSKBENT K_NOSUCHMAP NR_KEYS MAX_NR_KEYMAPS BLKRRPART TIOCSCTTY +       HDIO_GETGEO LOOP_GET_STATUS +       MS_MGC_VAL O_WRONLY O_RDWR O_CREAT O_NONBLOCK F_SETFL F_GETFL WNOHANG +       VT_ACTIVATE VT_WAITACTIVE VT_GETSTATE +       CDROMEJECT CDROMCLOSETRAY CDROM_LOCKDOOR         LOG_WARNING LOG_INFO LOG_LOCAL1 +       LC_COLLATE         ) ],  ); @@ -577,3 +851,7 @@ END      }  } +print ' + +PROTOTYPES: DISABLE +'; | 
