[ARM]
- don't clobber the parameter regs in the entry point, - fix entry point address for netbsd loader emulation, - added a gUImage global to point to the uimage blob with the tgz, - added tgz info to platform stage2 args, - add simple uimage support, just dumps the header and gets the nth blob in the image, (seems we have a bug in the math code, some infos don't print), - made devices.cpp use them to publish the MemoryDisk, - add an haiku_loader_nbsd.ub target which puts both the loader and kernel_arm for now (need to replace with the tgz). git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@32295 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
f4e0ad68b3
commit
01c8294cc7
@ -11,7 +11,7 @@ HAIKU_BOARD_DESCRIPTION = "Gumstix Overo" ;
|
|||||||
HAIKU_BOARD_LOADER_BASE = 0x80008000 ;
|
HAIKU_BOARD_LOADER_BASE = 0x80008000 ;
|
||||||
# entry points (raw binary, and netbsd loader emulation)
|
# entry points (raw binary, and netbsd loader emulation)
|
||||||
HAIKU_BOARD_LOADER_ENTRY_RAW = 0x80008000 ;
|
HAIKU_BOARD_LOADER_ENTRY_RAW = 0x80008000 ;
|
||||||
HAIKU_BOARD_LOADER_ENTRY_NBSD = 0x80008004 ;
|
HAIKU_BOARD_LOADER_ENTRY_NBSD = 0x80008008 ;
|
||||||
|
|
||||||
# load address for haiku_loader uimage
|
# load address for haiku_loader uimage
|
||||||
# (must be different than real load address)
|
# (must be different than real load address)
|
||||||
@ -36,7 +36,9 @@ HAIKU_BOARD_SDIMAGE_BFS_OFFSET = ;
|
|||||||
|
|
||||||
# autoboot script
|
# autoboot script
|
||||||
HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME = gumstix-factory.script ;
|
HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME = gumstix-factory.script ;
|
||||||
HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT = "if mmcinit; then \
|
HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT = "\
|
||||||
|
setenv bootargs debug_screen true; \
|
||||||
|
if mmcinit; then \
|
||||||
fatload mmc 0 $(HAIKU_BOARD_LOADER_UIBASE) haiku_loader.ub; \
|
fatload mmc 0 $(HAIKU_BOARD_LOADER_UIBASE) haiku_loader.ub; \
|
||||||
bootm $(HAIKU_BOARD_LOADER_UIBASE); \
|
bootm $(HAIKU_BOARD_LOADER_UIBASE); \
|
||||||
fi" ;
|
fi" ;
|
||||||
@ -44,6 +46,7 @@ fi" ;
|
|||||||
HAIKU_BOARD_SDIMAGE_FILES =
|
HAIKU_BOARD_SDIMAGE_FILES =
|
||||||
haiku_loader
|
haiku_loader
|
||||||
haiku_loader.ub
|
haiku_loader.ub
|
||||||
|
haiku_loader_nbsd.ub
|
||||||
$(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME)
|
$(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME)
|
||||||
;
|
;
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ HAIKU_BOARD_DESCRIPTION = "Gumstix Verdex" ;
|
|||||||
HAIKU_BOARD_LOADER_BASE = 0xa2000000 ;
|
HAIKU_BOARD_LOADER_BASE = 0xa2000000 ;
|
||||||
# entry points (raw binary, and netbsd loader emulation)
|
# entry points (raw binary, and netbsd loader emulation)
|
||||||
HAIKU_BOARD_LOADER_ENTRY_RAW = 0xa2000000 ;
|
HAIKU_BOARD_LOADER_ENTRY_RAW = 0xa2000000 ;
|
||||||
HAIKU_BOARD_LOADER_ENTRY_NBSD = 0xa2000004 ;
|
HAIKU_BOARD_LOADER_ENTRY_NBSD = 0xa2000008 ;
|
||||||
|
|
||||||
# load address for haiku_loader uimage
|
# load address for haiku_loader uimage
|
||||||
# (must be different than real load address)
|
# (must be different than real load address)
|
||||||
@ -46,14 +46,17 @@ HAIKU_BOARD_SDIMAGE_FAT_SIZE = 32 ;
|
|||||||
# autoboot script
|
# autoboot script
|
||||||
HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME = gumstix-factory.script ;
|
HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME = gumstix-factory.script ;
|
||||||
|
|
||||||
HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT = "if mmcinit; then \
|
HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT = "\
|
||||||
fatload mmc 0 $(HAIKU_BOARD_LOADER_UIBASE) haiku_loader.ub; \
|
setenv bootargs debug_screen true; \
|
||||||
|
if mmcinit; then \
|
||||||
|
fatload mmc 0 $(HAIKU_BOARD_LOADER_UIBASE) haiku_loader_nbsd.ub; \
|
||||||
bootm $(HAIKU_BOARD_LOADER_UIBASE); \
|
bootm $(HAIKU_BOARD_LOADER_UIBASE); \
|
||||||
fi" ;
|
fi" ;
|
||||||
|
|
||||||
HAIKU_BOARD_SDIMAGE_FILES =
|
HAIKU_BOARD_SDIMAGE_FILES =
|
||||||
haiku_loader
|
haiku_loader
|
||||||
haiku_loader.ub
|
haiku_loader.ub
|
||||||
|
haiku_loader_nbsd.ub
|
||||||
$(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME)
|
$(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME)
|
||||||
;
|
;
|
||||||
|
|
||||||
|
@ -10,6 +10,8 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct platform_stage2_args {
|
struct platform_stage2_args {
|
||||||
|
void *boot_tgz_data;
|
||||||
|
uint32 boot_tgz_size;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* KERNEL_BOOT_PLATFORM_UBOOT_STAGE2_H */
|
#endif /* KERNEL_BOOT_PLATFORM_UBOOT_STAGE2_H */
|
||||||
|
54
headers/private/kernel/boot/platform/u-boot/uimage.h
Normal file
54
headers/private/kernel/boot/platform/u-boot/uimage.h
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2009 Haiku Inc. All rights reserved.
|
||||||
|
* Distributed under the terms of the MIT License.
|
||||||
|
*
|
||||||
|
* Authors:
|
||||||
|
* François Revol, revol@free.fr
|
||||||
|
*/
|
||||||
|
#ifndef KERNEL_BOOT_PLATFORM_UBOOT_UIMAGE_H
|
||||||
|
#define KERNEL_BOOT_PLATFORM_UBOOT_UIMAGE_H
|
||||||
|
|
||||||
|
#include <SupportDefs.h>
|
||||||
|
|
||||||
|
/* same type and constant names as U-Boot */
|
||||||
|
|
||||||
|
#define IH_TYPE_STANDALONE 1
|
||||||
|
#define IH_TYPE_KERNEL 2
|
||||||
|
#define IH_TYPE_RAMDISK 3
|
||||||
|
#define IH_TYPE_MULTI 4
|
||||||
|
|
||||||
|
#define IH_COMP_NONE 0
|
||||||
|
|
||||||
|
#define IH_MAGIC 0x27051956
|
||||||
|
#define IH_NMLEN 32
|
||||||
|
|
||||||
|
typedef struct image_header {
|
||||||
|
uint32 ih_magic;
|
||||||
|
uint32 ih_hcrc;
|
||||||
|
uint32 ih_time;
|
||||||
|
uint32 ih_size;
|
||||||
|
uint32 ih_load;
|
||||||
|
uint32 ih_ep;
|
||||||
|
uint32 ih_dcrc;
|
||||||
|
uint8 ih_os;
|
||||||
|
uint8 ih_arch;
|
||||||
|
uint8 ih_type;
|
||||||
|
uint8 ih_comp;
|
||||||
|
char ih_name[IH_NMLEN];
|
||||||
|
} image_header_t;
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void dump_uimage(struct image_header *image);
|
||||||
|
bool image_multi_getimg(struct image_header *image, uint32 idx,
|
||||||
|
uint32 *data, uint32 *size);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* KERNEL_BOOT_PLATFORM_UBOOT_UIMAGE_H */
|
@ -22,7 +22,7 @@ local uImageFakeOS = "netbsd" ;
|
|||||||
SEARCH_SOURCE += [ FDirName $(HAIKU_TOP) src add-ons accelerants common ] ;
|
SEARCH_SOURCE += [ FDirName $(HAIKU_TOP) src add-ons accelerants common ] ;
|
||||||
|
|
||||||
KernelMergeObject boot_platform_u-boot.o :
|
KernelMergeObject boot_platform_u-boot.o :
|
||||||
start.S
|
shell.S
|
||||||
start2.c
|
start2.c
|
||||||
debug.c
|
debug.c
|
||||||
console.cpp
|
console.cpp
|
||||||
@ -31,6 +31,7 @@ KernelMergeObject boot_platform_u-boot.o :
|
|||||||
keyboard.cpp
|
keyboard.cpp
|
||||||
menu.cpp
|
menu.cpp
|
||||||
cpu.cpp
|
cpu.cpp
|
||||||
|
uimage.cpp
|
||||||
video.cpp
|
video.cpp
|
||||||
mmu.cpp
|
mmu.cpp
|
||||||
# generic
|
# generic
|
||||||
@ -96,12 +97,14 @@ rule BuildUImage image : data : args
|
|||||||
Depends $(image) : $(data) ;
|
Depends $(image) : $(data) ;
|
||||||
LocalClean clean : $(image) ;
|
LocalClean clean : $(image) ;
|
||||||
MKIMAGE_ARGS on $(image) = $(args) ;
|
MKIMAGE_ARGS on $(image) = $(args) ;
|
||||||
|
colon on $(image) = ":" ;
|
||||||
|
local files = $(data:G=) ;
|
||||||
BuildUImage1 $(image) : $(data) ;
|
BuildUImage1 $(image) : $(data) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
actions BuildUImage1
|
actions BuildUImage1
|
||||||
{
|
{
|
||||||
mkimage $(MKIMAGE_ARGS) -d $(>) $(<)
|
mkimage $(MKIMAGE_ARGS) -d $(>:J=$(colon)) $(<)
|
||||||
}
|
}
|
||||||
|
|
||||||
rule BuildUImageScript script : content
|
rule BuildUImageScript script : content
|
||||||
@ -170,8 +173,12 @@ BuildUImage haiku_loader.ub : haiku_loader :
|
|||||||
-a $(HAIKU_BOARD_LOADER_BASE) -e $(HAIKU_BOARD_LOADER_ENTRY_RAW)
|
-a $(HAIKU_BOARD_LOADER_BASE) -e $(HAIKU_BOARD_LOADER_ENTRY_RAW)
|
||||||
-n 'haiku_loader' ;
|
-n 'haiku_loader' ;
|
||||||
|
|
||||||
|
BuildUImage haiku_loader_nbsd.ub : haiku_loader kernel_arm :
|
||||||
|
-A arm -O $(uImageFakeOS) -T multi -C none
|
||||||
|
-a $(HAIKU_BOARD_LOADER_BASE) -e $(HAIKU_BOARD_LOADER_ENTRY_NBSD)
|
||||||
|
-n 'haiku_loader' ;
|
||||||
|
|
||||||
if $(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME) {
|
if $(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME) {
|
||||||
|
|
||||||
BuildUImageScript $(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME) :
|
BuildUImageScript $(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT_NAME) :
|
||||||
$(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT) ;
|
$(HAIKU_BOARD_SDIMAGE_UBOOT_SCRIPT) ;
|
||||||
}
|
}
|
||||||
@ -187,6 +194,8 @@ BuildUBootFlashImage haiku_flash_image_uimage.img : haiku_loader.ub :
|
|||||||
# SD/mmc image targets
|
# SD/mmc image targets
|
||||||
BuildUBootSDImage haiku.mmc : $(HAIKU_BOARD_SDIMAGE_FILES) ;
|
BuildUBootSDImage haiku.mmc : $(HAIKU_BOARD_SDIMAGE_FILES) ;
|
||||||
|
|
||||||
|
SEARCH on [ FGristFiles shell.S ]
|
||||||
|
= [ FDirName $(HAIKU_TOP) src system boot platform $(TARGET_BOOT_PLATFORM) arch $(TARGET_ARCH) ] ;
|
||||||
SEARCH on [ FGristFiles text_menu.cpp ]
|
SEARCH on [ FGristFiles text_menu.cpp ]
|
||||||
= [ FDirName $(HAIKU_TOP) src system boot platform generic ] ;
|
= [ FDirName $(HAIKU_TOP) src system boot platform generic ] ;
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ SYMBOL(_start_raw):
|
|||||||
* ELF entry
|
* ELF entry
|
||||||
*/
|
*/
|
||||||
SYMBOL(_start):
|
SYMBOL(_start):
|
||||||
mov r0,#0
|
mov r4,#0
|
||||||
b _start_common
|
b _start_common
|
||||||
SYMBOL_END(_start_raw)
|
SYMBOL_END(_start_raw)
|
||||||
SYMBOL_END(_start)
|
SYMBOL_END(_start)
|
||||||
@ -27,20 +27,20 @@ SYMBOL_END(_start)
|
|||||||
* called from bootm with netbsd loader compatible args
|
* called from bootm with netbsd loader compatible args
|
||||||
*/
|
*/
|
||||||
SYMBOL(_start_netbsd):
|
SYMBOL(_start_netbsd):
|
||||||
mov r0,#1
|
mov r4,#1
|
||||||
b _start_common
|
b _start_common
|
||||||
SYMBOL_END(_start_netbsd)
|
SYMBOL_END(_start_netbsd)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
SYMBOL(_start_common):
|
SYMBOL(_start_common):
|
||||||
strb r0,gUBootOS
|
strb r4,gUBootOS
|
||||||
str r8,gUBootGlobalData
|
str r8,gUBootGlobalData
|
||||||
/* ... */
|
/* ... */
|
||||||
ldrb r0,gUBootOS
|
ldrb r4,gUBootOS
|
||||||
cmp r0,#0
|
cmp r4,#0
|
||||||
beq start_raw
|
beq start_raw
|
||||||
cmp r0,#1
|
cmp r4,#1
|
||||||
beq start_netbsd
|
beq start_netbsd
|
||||||
mov pc,lr
|
mov pc,lr
|
||||||
SYMBOL_END(_start_common)
|
SYMBOL_END(_start_common)
|
||||||
@ -51,6 +51,9 @@ SYMBOL_END(_start_common)
|
|||||||
SYMBOL(gUBootGlobalData):
|
SYMBOL(gUBootGlobalData):
|
||||||
.long 0
|
.long 0
|
||||||
SYMBOL_END(gUBootGlobalData)
|
SYMBOL_END(gUBootGlobalData)
|
||||||
|
SYMBOL(gUImage):
|
||||||
|
.long 0
|
||||||
|
SYMBOL_END(gUImage)
|
||||||
SYMBOL(gUBootOS):
|
SYMBOL(gUBootOS):
|
||||||
.byte 0
|
.byte 0
|
||||||
SYMBOL_END(gUBootOS)
|
SYMBOL_END(gUBootOS)
|
||||||
|
@ -23,13 +23,14 @@
|
|||||||
status_t
|
status_t
|
||||||
platform_add_boot_device(struct stage2_args *args, NodeList *devicesList)
|
platform_add_boot_device(struct stage2_args *args, NodeList *devicesList)
|
||||||
{
|
{
|
||||||
#warning ARM: correct/configurable "initrd" location
|
|
||||||
uint8* data = (uint8*)0xa5000000;
|
|
||||||
size_t size = 0;
|
|
||||||
|
|
||||||
TRACE("platform_add_boot_device\n");
|
TRACE("platform_add_boot_device\n");
|
||||||
|
|
||||||
MemoryDisk* disk = new(nothrow) MemoryDisk(data, size, "boot.tgz");
|
if (!args->platform.boot_tgz_data || !args->platform.boot_tgz_size)
|
||||||
|
return B_DEVICE_NOT_FOUND;
|
||||||
|
|
||||||
|
MemoryDisk* disk = new(nothrow) MemoryDisk(
|
||||||
|
(const uint8 *)args->platform.boot_tgz_data,
|
||||||
|
args->platform.boot_tgz_size, "boot.tgz");
|
||||||
if (!disk) {
|
if (!disk) {
|
||||||
dprintf("platform_add_boot_device(): Could not create MemoryDisk !\n");
|
dprintf("platform_add_boot_device(): Could not create MemoryDisk !\n");
|
||||||
return B_NO_MEMORY;
|
return B_NO_MEMORY;
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#include "console.h"
|
#include "console.h"
|
||||||
#include "cpu.h"
|
#include "cpu.h"
|
||||||
#include "smp.h"
|
#include "smp.h"
|
||||||
|
#include "uimage.h"
|
||||||
#include "keyboard.h"
|
#include "keyboard.h"
|
||||||
|
|
||||||
#include <KernelExport.h>
|
#include <KernelExport.h>
|
||||||
@ -31,6 +32,8 @@ extern uint8 _end;
|
|||||||
extern int main(stage2_args *args);
|
extern int main(stage2_args *args);
|
||||||
extern void _start(void);
|
extern void _start(void);
|
||||||
extern int start_raw(int argc, char **argv);
|
extern int start_raw(int argc, char **argv);
|
||||||
|
extern void dump_uimage(struct image_header *image);
|
||||||
|
extern struct image_header *gUImage;
|
||||||
|
|
||||||
|
|
||||||
uint32 sBootOptions;
|
uint32 sBootOptions;
|
||||||
@ -116,13 +119,14 @@ extern uboot_arm_gd *gUBootGlobalData;
|
|||||||
extern uint8 gUBootOS;
|
extern uint8 gUBootOS;
|
||||||
|
|
||||||
int
|
int
|
||||||
start_netbsd(struct board_info *bd, struct uimage *image, const char *consdev,
|
start_netbsd(struct board_info *bd, struct image_header *image, const char *consdev,
|
||||||
const char *cmdline)
|
const char *cmdline)
|
||||||
{
|
{
|
||||||
const char *argv[] = { "haiku", cmdline };
|
const char *argv[] = { "haiku", cmdline };
|
||||||
int argc = 1;
|
int argc = 1;
|
||||||
if (cmdline)
|
if (cmdline)
|
||||||
argc++;
|
argc++;
|
||||||
|
gUImage = image;
|
||||||
start_raw(argc, argv);
|
start_raw(argc, argv);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -142,6 +146,13 @@ start_raw(int argc, char **argv)
|
|||||||
call_ctors();
|
call_ctors();
|
||||||
args.heap_size = HEAP_SIZE;
|
args.heap_size = HEAP_SIZE;
|
||||||
args.arguments = NULL;
|
args.arguments = NULL;
|
||||||
|
args.platform.boot_tgz_data = NULL;
|
||||||
|
args.platform.boot_tgz_size = 0;
|
||||||
|
|
||||||
|
// if we get passed a uimage, try to find the second blob
|
||||||
|
if (gUImage)
|
||||||
|
image_multi_getimg(gUImage, 1, &args.platform.boot_tgz_data,
|
||||||
|
&args.platform.boot_tgz_size);
|
||||||
|
|
||||||
|
|
||||||
serial_init();
|
serial_init();
|
||||||
@ -156,6 +167,9 @@ start_raw(int argc, char **argv)
|
|||||||
dprintf("os: %d\n", gUBootOS);
|
dprintf("os: %d\n", gUBootOS);
|
||||||
dprintf("gd @ %p\n", gGD);
|
dprintf("gd @ %p\n", gGD);
|
||||||
dprintf("gd->bd @ %p\n", gGD->bd);
|
dprintf("gd->bd @ %p\n", gGD->bd);
|
||||||
|
dprintf("uimage @ %p\n", gUImage);
|
||||||
|
if (gUImage)
|
||||||
|
dump_uimage(gUImage);
|
||||||
}
|
}
|
||||||
|
|
||||||
// mmu_init();
|
// mmu_init();
|
||||||
|
61
src/system/boot/platform/u-boot/uimage.cpp
Normal file
61
src/system/boot/platform/u-boot/uimage.cpp
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2009, François Revol, revol@free.fr.
|
||||||
|
* Distributed under the terms of the MIT License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <uimage.h>
|
||||||
|
|
||||||
|
#include <KernelExport.h>
|
||||||
|
#include <ByteOrder.h>
|
||||||
|
|
||||||
|
|
||||||
|
void dump_uimage(struct image_header *image)
|
||||||
|
{
|
||||||
|
uint32 *sizes;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
dprintf("uimage @ %p:\n", image);
|
||||||
|
|
||||||
|
if (!image)
|
||||||
|
return;
|
||||||
|
dprintf("magic: %x\n", ntohl(image->ih_magic));
|
||||||
|
dprintf("size: %x\n", ntohl(image->ih_size));
|
||||||
|
dprintf("load: %p\n", (void *)ntohl(image->ih_load));
|
||||||
|
dprintf("ep: %d\n", (void *)ntohl(image->ih_ep));
|
||||||
|
dprintf("os: %d\n", image->ih_os);
|
||||||
|
dprintf("arch: %d\n", image->ih_arch);
|
||||||
|
dprintf("type: %d\n", image->ih_type);
|
||||||
|
dprintf("comp: %d\n", image->ih_comp);
|
||||||
|
dprintf("name: '%32.32s'\n", image->ih_name);
|
||||||
|
if (image->ih_type != IH_TYPE_MULTI)
|
||||||
|
return;
|
||||||
|
sizes = (uint32 *)(&image[1]);
|
||||||
|
for (i = 0; sizes[i]; i++) {
|
||||||
|
dprintf("contents[%d] :", i);
|
||||||
|
dprintf("%x bytes\n", (int)ntohl(sizes[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool
|
||||||
|
image_multi_getimg(struct image_header *image, uint32 idx, uint32 *data, uint32 *size)
|
||||||
|
{
|
||||||
|
uint32 *sizes;
|
||||||
|
uint32 base;
|
||||||
|
int i, count = 0;
|
||||||
|
|
||||||
|
sizes = (uint32 *)(&image[1]);
|
||||||
|
base = (uint32)sizes;
|
||||||
|
for (i = 0; sizes[i]; i++)
|
||||||
|
count++;
|
||||||
|
base += (count + 1) * sizeof(uint32);
|
||||||
|
for (i = 0; sizes[i] && idx < i; i++) {
|
||||||
|
if (idx == i) {
|
||||||
|
*data = base;
|
||||||
|
*size = ntohl(sizes[i]);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user