mirror of
https://github.com/sheumann/hush.git
synced 2025-01-20 05:30:25 +00:00
fdisk: code shrink without logic changes
function old new delta create_doslabel 113 110 -3 set_start_sect 8 4 -4 set_nr_sects 8 4 -4 get_start_sect 8 4 -4 get_nr_sects 8 4 -4 store4_little_endian 21 - -21 read4_little_endian 33 - -33 is_cleared_partition 84 21 -63 ------------------------------------------------------------------------------ (add/remove: 0/2 grow/shrink: 0/6 up/down: 0/-136) Total: -136 bytes Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
37bc1eb5cd
commit
5ea1de2235
@ -21,6 +21,13 @@
|
|||||||
#endif
|
#endif
|
||||||
#include "libbb.h"
|
#include "libbb.h"
|
||||||
|
|
||||||
|
#if BB_LITTLE_ENDIAN
|
||||||
|
# define inline_if_little_endian ALWAYS_INLINE
|
||||||
|
#else
|
||||||
|
# define inline_if_little_endian /* nothing */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* Looks like someone forgot to add this to config system */
|
/* Looks like someone forgot to add this to config system */
|
||||||
#ifndef ENABLE_FEATURE_FDISK_BLKSIZE
|
#ifndef ENABLE_FEATURE_FDISK_BLKSIZE
|
||||||
# define ENABLE_FEATURE_FDISK_BLKSIZE 0
|
# define ENABLE_FEATURE_FDISK_BLKSIZE 0
|
||||||
@ -181,7 +188,7 @@ struct pte {
|
|||||||
sector_t offset; /* disk sector number */
|
sector_t offset; /* disk sector number */
|
||||||
char *sectorbuffer; /* disk sector contents */
|
char *sectorbuffer; /* disk sector contents */
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
#if ENABLE_FEATURE_FDISK_WRITABLE
|
||||||
char changed; /* boolean */
|
char changed; /* boolean */
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -445,27 +452,6 @@ close_dev_fd(void)
|
|||||||
xmove_fd(xopen(bb_dev_null, O_RDONLY), dev_fd);
|
xmove_fd(xopen(bb_dev_null, O_RDONLY), dev_fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
|
||||||
/* Read line; return 0 or first printable char */
|
|
||||||
static int
|
|
||||||
read_line(const char *prompt)
|
|
||||||
{
|
|
||||||
int sz;
|
|
||||||
|
|
||||||
sz = read_line_input(prompt, line_buffer, sizeof(line_buffer), NULL);
|
|
||||||
if (sz <= 0)
|
|
||||||
exit(EXIT_SUCCESS); /* Ctrl-D or Ctrl-C */
|
|
||||||
|
|
||||||
if (line_buffer[sz-1] == '\n')
|
|
||||||
line_buffer[--sz] = '\0';
|
|
||||||
|
|
||||||
line_ptr = line_buffer;
|
|
||||||
while (*line_ptr != '\0' && (unsigned char)*line_ptr <= ' ')
|
|
||||||
line_ptr++;
|
|
||||||
return *line_ptr;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Return partition name - uses static storage
|
* Return partition name - uses static storage
|
||||||
*/
|
*/
|
||||||
@ -497,30 +483,13 @@ partname(const char *dev, int pno, int lth)
|
|||||||
|
|
||||||
if (lth) {
|
if (lth) {
|
||||||
snprintf(bufp, bufsiz, "%*.*s%s%-2u",
|
snprintf(bufp, bufsiz, "%*.*s%s%-2u",
|
||||||
lth-wp-2, w, dev, p, pno);
|
lth-wp-2, w, dev, p, pno);
|
||||||
} else {
|
} else {
|
||||||
snprintf(bufp, bufsiz, "%.*s%s%-2u", w, dev, p, pno);
|
snprintf(bufp, bufsiz, "%.*s%s%-2u", w, dev, p, pno);
|
||||||
}
|
}
|
||||||
return bufp;
|
return bufp;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
|
||||||
static void
|
|
||||||
set_all_unchanged(void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 0; i < MAXIMUM_PARTS; i++)
|
|
||||||
ptes[i].changed = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static ALWAYS_INLINE void
|
|
||||||
set_changed(int i)
|
|
||||||
{
|
|
||||||
ptes[i].changed = 1;
|
|
||||||
}
|
|
||||||
#endif /* FEATURE_FDISK_WRITABLE */
|
|
||||||
|
|
||||||
static ALWAYS_INLINE struct partition *
|
static ALWAYS_INLINE struct partition *
|
||||||
get_part_table(int i)
|
get_part_table(int i)
|
||||||
{
|
{
|
||||||
@ -541,7 +510,67 @@ valid_part_table_flag(const char *mbuffer)
|
|||||||
return (mbuffer[510] == 0x55 && (uint8_t)mbuffer[511] == 0xaa);
|
return (mbuffer[510] == 0x55 && (uint8_t)mbuffer[511] == 0xaa);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void fdisk_fatal(const char *why)
|
||||||
|
{
|
||||||
|
if (listing) {
|
||||||
|
close_dev_fd();
|
||||||
|
longjmp(listingbuf, 1);
|
||||||
|
}
|
||||||
|
bb_error_msg_and_die(why, disk_device);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
seek_sector(sector_t secno)
|
||||||
|
{
|
||||||
|
#if ENABLE_FDISK_SUPPORT_LARGE_DISKS
|
||||||
|
off64_t off = (off64_t)secno * sector_size;
|
||||||
|
if (lseek64(dev_fd, off, SEEK_SET) == (off64_t) -1)
|
||||||
|
fdisk_fatal(unable_to_seek);
|
||||||
|
#else
|
||||||
|
uint64_t off = (uint64_t)secno * sector_size;
|
||||||
|
if (off > MAXINT(off_t)
|
||||||
|
|| lseek(dev_fd, (off_t)off, SEEK_SET) == (off_t) -1
|
||||||
|
) {
|
||||||
|
fdisk_fatal(unable_to_seek);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
#if ENABLE_FEATURE_FDISK_WRITABLE
|
||||||
|
/* Read line; return 0 or first printable char */
|
||||||
|
static int
|
||||||
|
read_line(const char *prompt)
|
||||||
|
{
|
||||||
|
int sz;
|
||||||
|
|
||||||
|
sz = read_line_input(prompt, line_buffer, sizeof(line_buffer), NULL);
|
||||||
|
if (sz <= 0)
|
||||||
|
exit(EXIT_SUCCESS); /* Ctrl-D or Ctrl-C */
|
||||||
|
|
||||||
|
if (line_buffer[sz-1] == '\n')
|
||||||
|
line_buffer[--sz] = '\0';
|
||||||
|
|
||||||
|
line_ptr = line_buffer;
|
||||||
|
while (*line_ptr != '\0' && (unsigned char)*line_ptr <= ' ')
|
||||||
|
line_ptr++;
|
||||||
|
return *line_ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
set_all_unchanged(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < MAXIMUM_PARTS; i++)
|
||||||
|
ptes[i].changed = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static ALWAYS_INLINE void
|
||||||
|
set_changed(int i)
|
||||||
|
{
|
||||||
|
ptes[i].changed = 1;
|
||||||
|
}
|
||||||
|
|
||||||
static ALWAYS_INLINE void
|
static ALWAYS_INLINE void
|
||||||
write_part_table_flag(char *b)
|
write_part_table_flag(char *b)
|
||||||
{
|
{
|
||||||
@ -579,48 +608,18 @@ read_hex(const char *const *sys)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
v = bb_strtoul(line_ptr, NULL, 16);
|
v = bb_strtoul(line_ptr, NULL, 16);
|
||||||
if (v > 0xff)
|
if (v <= 0xff)
|
||||||
/* Bad input also triggers this */
|
return v;
|
||||||
continue;
|
|
||||||
return v;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* FEATURE_FDISK_WRITABLE */
|
|
||||||
|
|
||||||
static void fdisk_fatal(const char *why)
|
|
||||||
{
|
|
||||||
if (listing) {
|
|
||||||
close_dev_fd();
|
|
||||||
longjmp(listingbuf, 1);
|
|
||||||
}
|
|
||||||
bb_error_msg_and_die(why, disk_device);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
seek_sector(sector_t secno)
|
|
||||||
{
|
|
||||||
#if ENABLE_FDISK_SUPPORT_LARGE_DISKS
|
|
||||||
off64_t off = (off64_t)secno * sector_size;
|
|
||||||
if (lseek64(dev_fd, off, SEEK_SET) == (off64_t) -1)
|
|
||||||
fdisk_fatal(unable_to_seek);
|
|
||||||
#else
|
|
||||||
uint64_t off = (uint64_t)secno * sector_size;
|
|
||||||
if (off > MAXINT(off_t)
|
|
||||||
|| lseek(dev_fd, (off_t)off, SEEK_SET) == (off_t) -1
|
|
||||||
) {
|
|
||||||
fdisk_fatal(unable_to_seek);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
|
||||||
static void
|
static void
|
||||||
write_sector(sector_t secno, const void *buf)
|
write_sector(sector_t secno, const void *buf)
|
||||||
{
|
{
|
||||||
seek_sector(secno);
|
seek_sector(secno);
|
||||||
xwrite(dev_fd, buf, sector_size);
|
xwrite(dev_fd, buf, sector_size);
|
||||||
}
|
}
|
||||||
#endif
|
#endif /* FEATURE_FDISK_WRITABLE */
|
||||||
|
|
||||||
|
|
||||||
#include "fdisk_aix.c"
|
#include "fdisk_aix.c"
|
||||||
@ -713,40 +712,42 @@ STATIC_SUN void sun_write_table(void);
|
|||||||
#include "fdisk_sun.c"
|
#include "fdisk_sun.c"
|
||||||
|
|
||||||
|
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
static inline_if_little_endian unsigned
|
||||||
/* start_sect and nr_sects are stored little endian on all machines */
|
|
||||||
/* moreover, they are not aligned correctly */
|
|
||||||
static void
|
|
||||||
store4_little_endian(unsigned char *cp, unsigned val)
|
|
||||||
{
|
|
||||||
cp[0] = val;
|
|
||||||
cp[1] = val >> 8;
|
|
||||||
cp[2] = val >> 16;
|
|
||||||
cp[3] = val >> 24;
|
|
||||||
}
|
|
||||||
#endif /* FEATURE_FDISK_WRITABLE */
|
|
||||||
|
|
||||||
static unsigned
|
|
||||||
read4_little_endian(const unsigned char *cp)
|
read4_little_endian(const unsigned char *cp)
|
||||||
{
|
{
|
||||||
return cp[0] + (cp[1] << 8) + (cp[2] << 16) + (cp[3] << 24);
|
uint32_t v;
|
||||||
|
move_from_unaligned32(v, cp);
|
||||||
|
return SWAP_LE32(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
|
||||||
static void
|
|
||||||
set_start_sect(struct partition *p, unsigned start_sect)
|
|
||||||
{
|
|
||||||
store4_little_endian(p->start4, start_sect);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static sector_t
|
static sector_t
|
||||||
get_start_sect(const struct partition *p)
|
get_start_sect(const struct partition *p)
|
||||||
{
|
{
|
||||||
return read4_little_endian(p->start4);
|
return read4_little_endian(p->start4);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static sector_t
|
||||||
|
get_nr_sects(const struct partition *p)
|
||||||
|
{
|
||||||
|
return read4_little_endian(p->size4);
|
||||||
|
}
|
||||||
|
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
#if ENABLE_FEATURE_FDISK_WRITABLE
|
||||||
|
/* start_sect and nr_sects are stored little endian on all machines */
|
||||||
|
/* moreover, they are not aligned correctly */
|
||||||
|
static inline_if_little_endian void
|
||||||
|
store4_little_endian(unsigned char *cp, unsigned val)
|
||||||
|
{
|
||||||
|
uint32_t v = SWAP_LE32(val);
|
||||||
|
move_to_unaligned32(cp, v);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
set_start_sect(struct partition *p, unsigned start_sect)
|
||||||
|
{
|
||||||
|
store4_little_endian(p->start4, start_sect);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
set_nr_sects(struct partition *p, unsigned nr_sects)
|
set_nr_sects(struct partition *p, unsigned nr_sects)
|
||||||
{
|
{
|
||||||
@ -754,12 +755,6 @@ set_nr_sects(struct partition *p, unsigned nr_sects)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static sector_t
|
|
||||||
get_nr_sects(const struct partition *p)
|
|
||||||
{
|
|
||||||
return read4_little_endian(p->size4);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Allocate a buffer and read a partition table sector */
|
/* Allocate a buffer and read a partition table sector */
|
||||||
static void
|
static void
|
||||||
read_pte(struct pte *pe, sector_t offset)
|
read_pte(struct pte *pe, sector_t offset)
|
||||||
@ -942,7 +937,7 @@ get_sys_types(void)
|
|||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
#define get_sys_types() i386_sys_types
|
#define get_sys_types() i386_sys_types
|
||||||
#endif /* FEATURE_FDISK_WRITABLE */
|
#endif
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
partition_type(unsigned char type)
|
partition_type(unsigned char type)
|
||||||
@ -957,6 +952,24 @@ partition_type(unsigned char type)
|
|||||||
return "Unknown";
|
return "Unknown";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
is_cleared_partition(const struct partition *p)
|
||||||
|
{
|
||||||
|
/* We consider partition "cleared" only if it has only zeros */
|
||||||
|
const char *cp = (const char *)p;
|
||||||
|
int cnt = sizeof(*p);
|
||||||
|
char bits = 0;
|
||||||
|
while (--cnt >= 0)
|
||||||
|
bits |= *cp++;
|
||||||
|
return (bits == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
clear_partition(struct partition *p)
|
||||||
|
{
|
||||||
|
if (p)
|
||||||
|
memset(p, 0, sizeof(*p));
|
||||||
|
}
|
||||||
|
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
#if ENABLE_FEATURE_FDISK_WRITABLE
|
||||||
static int
|
static int
|
||||||
@ -998,25 +1011,7 @@ list_types(const char *const *sys)
|
|||||||
} while (done < last[0]);
|
} while (done < last[0]);
|
||||||
bb_putchar('\n');
|
bb_putchar('\n');
|
||||||
}
|
}
|
||||||
#endif /* FEATURE_FDISK_WRITABLE */
|
|
||||||
|
|
||||||
static int
|
|
||||||
is_cleared_partition(const struct partition *p)
|
|
||||||
{
|
|
||||||
return !(!p || p->boot_ind || p->head || p->sector || p->cyl ||
|
|
||||||
p->sys_ind || p->end_head || p->end_sector || p->end_cyl ||
|
|
||||||
get_start_sect(p) || get_nr_sects(p));
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
clear_partition(struct partition *p)
|
|
||||||
{
|
|
||||||
if (!p)
|
|
||||||
return;
|
|
||||||
memset(p, 0, sizeof(struct partition));
|
|
||||||
}
|
|
||||||
|
|
||||||
#if ENABLE_FEATURE_FDISK_WRITABLE
|
|
||||||
static void
|
static void
|
||||||
set_partition(int i, int doext, sector_t start, sector_t stop, int sysid)
|
set_partition(int i, int doext, sector_t start, sector_t stop, int sysid)
|
||||||
{
|
{
|
||||||
@ -1189,26 +1184,22 @@ read_extended(int ext)
|
|||||||
static void
|
static void
|
||||||
create_doslabel(void)
|
create_doslabel(void)
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
|
|
||||||
printf(msg_building_new_label, "DOS disklabel");
|
printf(msg_building_new_label, "DOS disklabel");
|
||||||
|
|
||||||
current_label_type = LABEL_DOS;
|
current_label_type = LABEL_DOS;
|
||||||
|
|
||||||
#if ENABLE_FEATURE_OSF_LABEL
|
#if ENABLE_FEATURE_OSF_LABEL
|
||||||
possibly_osf_label = 0;
|
possibly_osf_label = 0;
|
||||||
#endif
|
#endif
|
||||||
g_partitions = 4;
|
g_partitions = 4;
|
||||||
|
|
||||||
for (i = 510-64; i < 510; i++)
|
memset(&MBRbuffer[510 - 4*16], 0, 4*16);
|
||||||
MBRbuffer[i] = 0;
|
|
||||||
write_part_table_flag(MBRbuffer);
|
write_part_table_flag(MBRbuffer);
|
||||||
extended_offset = 0;
|
extended_offset = 0;
|
||||||
set_all_unchanged();
|
set_all_unchanged();
|
||||||
set_changed(0);
|
set_changed(0);
|
||||||
get_boot(CREATE_EMPTY_DOS);
|
get_boot(CREATE_EMPTY_DOS);
|
||||||
}
|
}
|
||||||
#endif /* FEATURE_FDISK_WRITABLE */
|
#endif
|
||||||
|
|
||||||
static void
|
static void
|
||||||
get_sectorsize(void)
|
get_sectorsize(void)
|
||||||
@ -1721,9 +1712,10 @@ delete_partition(int i)
|
|||||||
ptes[i] = ptes[i+1];
|
ptes[i] = ptes[i+1];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
} else
|
} else {
|
||||||
/* the only logical: clear only */
|
/* the only logical: clear only */
|
||||||
clear_partition(ptes[i].part_table);
|
clear_partition(ptes[i].part_table);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user