mirror of
https://github.com/apache/nuttx.git
synced 2026-06-04 14:53:47 +08:00
Easing in binfmt support
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@1892 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
+1
-1
@@ -42,7 +42,7 @@ SUBDIRS = libnxflat
|
||||
ASRCS = $(LIBNXFLAT_ASRCS)
|
||||
AOBJS = $(ASRCS:.S=$(OBJEXT))
|
||||
|
||||
CSRCS = $(LIBNXFLAT_CSRCS)
|
||||
CSRCS = nxflat.c $(LIBNXFLAT_CSRCS)
|
||||
COBJS = $(CSRCS:.c=$(OBJEXT))
|
||||
|
||||
SRCS = $(ASRCS) $(CSRCS)
|
||||
|
||||
@@ -34,4 +34,5 @@
|
||||
############################################################################
|
||||
|
||||
LIBNXFLAT_ASRCS =
|
||||
LIBNXFLAT_CSRCS = libnxflat_load.c libnxflat_stack.c libnxflat_verify.c
|
||||
LIBNXFLAT_CSRCS = libnxflat_init.c libnxflat_uninit.c libnxflat_load.c \
|
||||
libnxflat_unload.c libnxflat_verify.c libnxflat_read.c
|
||||
|
||||
@@ -0,0 +1,170 @@
|
||||
/****************************************************************************
|
||||
* binfmt/libnxflat/libnxflat_init.c
|
||||
*
|
||||
* Copyright (C) 2009 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
|
||||
#include <string.h>
|
||||
#include <fcntl.h>
|
||||
#include <nxflat.h>
|
||||
#include <debug.h>
|
||||
#include <errno.h>
|
||||
|
||||
#include <arpa/inet.h>
|
||||
#include <nuttx/nxflat.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-Processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Constant Data
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_init
|
||||
****************************************************************************/
|
||||
|
||||
int nxflat_init(const char *filename, struct nxflat_hdr_s *header,
|
||||
struct nxflat_loadinfo_s *loadinfo)
|
||||
{
|
||||
uint32 datastart;
|
||||
uint32 dataend;
|
||||
uint32 bssstart;
|
||||
uint32 bssend;
|
||||
int ret;
|
||||
|
||||
bvdbg("filename: %s header: %p loadinfo: %p\n", filename, header, loadinfo);
|
||||
|
||||
/* Clear the load info structure */
|
||||
|
||||
memset(loadinfo, 0, sizeof(struct nxflat_loadinfo_s));
|
||||
|
||||
/* Open the binary file */
|
||||
|
||||
loadinfo->filfd = open(filename, O_RDONLY);
|
||||
if (loadinfo->filfd < 0)
|
||||
{
|
||||
bdbg("Failed to open NXFLAT binary %s: %d\n", filename, ret);
|
||||
return -errno;
|
||||
}
|
||||
|
||||
/* Read the NXFLAT header from offset 0 */
|
||||
|
||||
ret = nxflat_read(loadinfo, (char*)&header, sizeof(struct nxflat_hdr_s), 0);
|
||||
if (ret < 0)
|
||||
{
|
||||
bdbg("Failed to read NXFLAT header: %d\n", ret);
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* Verify the NXFLAT header */
|
||||
|
||||
if (nxflat_verifyheader(header) != 0)
|
||||
{
|
||||
/* This is not an error because we will be called to attempt loading
|
||||
* EVERY binary. Returning -ENOEXEC simply informs the system that
|
||||
* the file is not an NXFLAT file. Besides, if there is something worth
|
||||
* complaining about, nnxflat_verifyheader() has already
|
||||
* done so.
|
||||
*/
|
||||
|
||||
bdbg("Bad NXFLAT header\n");
|
||||
return -ENOEXEC;
|
||||
}
|
||||
|
||||
/* Save all of the input values in the loadinfo structure */
|
||||
|
||||
loadinfo->header = header;
|
||||
|
||||
/* And extract some additional information from the xflat
|
||||
* header. Note that the information in the xflat header is in
|
||||
* network order.
|
||||
*/
|
||||
|
||||
datastart = ntohl(header->h_datastart);
|
||||
dataend = ntohl(header->h_dataend);
|
||||
bssstart = dataend;
|
||||
bssend = ntohl(header->h_bssend);
|
||||
|
||||
/* And put this information into the loadinfo structure as well.
|
||||
*
|
||||
* Note that:
|
||||
*
|
||||
* ispace_size = the address range from 0 up to datastart.
|
||||
* data_size = the address range from datastart up to dataend
|
||||
* bss_size = the address range from dataend up to bssend.
|
||||
*/
|
||||
|
||||
loadinfo->entry_offset = ntohl(header->h_entry);
|
||||
loadinfo->ispace_size = datastart;
|
||||
|
||||
loadinfo->data_size = dataend - datastart;
|
||||
loadinfo->bss_size = bssend - dataend;
|
||||
loadinfo->stack_size = ntohl(header->h_stacksize);
|
||||
|
||||
/* This is the initial dspace size. We'll recaculate this later
|
||||
* after the memory has been allocated. So that the caller can feel
|
||||
* free to modify dspace_size values from now until then.
|
||||
*/
|
||||
|
||||
loadinfo->dspace_size = /* Total DSpace Size is: */
|
||||
(NXFLAT_DATA_OFFSET + /* Memory set aside for ldso */
|
||||
bssend - datastart + /* Data and bss segment sizes */
|
||||
loadinfo->stack_size); /* (Current) stack size */
|
||||
|
||||
/* Get the offset to the start of the relocations (we'll relocate
|
||||
* this later).
|
||||
*/
|
||||
|
||||
loadinfo->reloc_start = ntohl(header->h_relocstart);
|
||||
loadinfo->reloc_count = ntohl(header->h_reloccount);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
+111
-285
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,123 @@
|
||||
/****************************************************************************
|
||||
* binfmt/libnxflat/libnxflat_read.c
|
||||
*
|
||||
* Copyright (C) 2009 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
#include <sys/types.h>
|
||||
|
||||
#include <unistd.h>
|
||||
#include <string.h>
|
||||
#include <nxflat.h>
|
||||
#include <debug.h>
|
||||
#include <errno.h>
|
||||
|
||||
#include <arpa/inet.h>
|
||||
#include <nuttx/nxflat.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-Processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Constant Data
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_read
|
||||
****************************************************************************/
|
||||
|
||||
int nxflat_read(struct nxflat_loadinfo_s *loadinfo, char *buffer, int readsize, int offset)
|
||||
{
|
||||
ssize_t nbytes; /* Number of bytes read */
|
||||
off_t rpos; /* Position returned by lseek */
|
||||
char *bufptr; /* Next buffer location to read into */
|
||||
int bytesleft; /* Number of bytes of .data left to read */
|
||||
int bytesread; /* Total number of bytes read */
|
||||
|
||||
/* Seek to the position in the object file where the initialized
|
||||
* data is saved.
|
||||
*/
|
||||
|
||||
bytesread = 0;
|
||||
bufptr = buffer;
|
||||
bytesleft = readsize;
|
||||
do
|
||||
{
|
||||
rpos = lseek(loadinfo->filfd, offset, SEEK_SET);
|
||||
if (rpos != offset)
|
||||
{
|
||||
bdbg("Failed to seek to position %d: %d\n", offset, errno);
|
||||
return -errno;
|
||||
}
|
||||
|
||||
/* Read the file data at offset into the user buffer */
|
||||
|
||||
nbytes = read(loadinfo->filfd, bufptr, bytesleft);
|
||||
if (nbytes < 0)
|
||||
{
|
||||
if (errno != EINTR)
|
||||
{
|
||||
bdbg("Read of .data failed: %d\n", errno);
|
||||
return -errno;
|
||||
}
|
||||
}
|
||||
else if (nbytes == 0)
|
||||
{
|
||||
bdbg("Unexpected end of file\n");
|
||||
return -ENODATA;
|
||||
}
|
||||
else
|
||||
{
|
||||
bytesread += nbytes;
|
||||
bytesleft -= nbytes;
|
||||
bufptr += nbytes;
|
||||
offset += nbytes;
|
||||
}
|
||||
}
|
||||
while (bytesread < readsize);
|
||||
return OK;
|
||||
}
|
||||
|
||||
@@ -1,224 +0,0 @@
|
||||
/****************************************************************************
|
||||
* libnxflat/lib/nxflat_stack.c
|
||||
*
|
||||
* Copyright (C) 2009 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
#include <sys/types.h>
|
||||
#include <debug.h>
|
||||
#include <errno.h>
|
||||
#include <nuttx/nxflat.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_adjuststacksize
|
||||
****************************************************************************/
|
||||
|
||||
void nxflat_adjuststacksize(struct nxflat_loadinfo_s *load_info,
|
||||
int argc, int envc, int system_usage)
|
||||
{
|
||||
uint32 total_usage = system_usage;
|
||||
|
||||
/* For argc, we will store the array (argc elements), the argc
|
||||
* value itself, plus a null pointer.
|
||||
*/
|
||||
|
||||
total_usage += (argc + 2) * sizeof(uint32);
|
||||
|
||||
/* For envc, we will store the array (envc elements) plus a null
|
||||
* pointer.
|
||||
*/
|
||||
|
||||
total_usage += (envc + 1) * sizeof(uint32);
|
||||
|
||||
/* And we will store six additional words described the memory
|
||||
* layout.
|
||||
*/
|
||||
|
||||
total_usage += 6 * sizeof(uint32);
|
||||
|
||||
/* Add this to the previously determined stack size */
|
||||
|
||||
load_info->stack_size += total_usage;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_initstack
|
||||
*
|
||||
* Description:
|
||||
* When we enter the NXFLAT_ loader, it will expect to see a stack frame
|
||||
* like the following. NOTE: This logic assumes a push down stack
|
||||
* (i.e., we decrement the stack pointer to go from the "BOTTOM" to
|
||||
* the "TOP").
|
||||
*
|
||||
*
|
||||
* TOP->argc Argument count (integer)
|
||||
* argv[0...(argc-1)] Program arguments (pointers)
|
||||
* NULL Marks end of arguments
|
||||
* env[0...N] Environment variables (pointers)
|
||||
* NULL Marks end of environment variables
|
||||
* loader ispace Address of loader ISpace (NXFLAT_ header)
|
||||
* loader dspace Address of loader DSpace
|
||||
* loader dspace size Size of the allocated loader DSpace
|
||||
* program ispace Address of program ISpace (NXFLAT_ header)
|
||||
* program dspace Address of program DSpace
|
||||
* BOTTOM->program dspace size Size of the allocated program DSpace
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
uint32 nxflat_initstack(struct nxflat_loadinfo_s *prog_load_info,
|
||||
struct nxflat_loadinfo_s *lib_load_info,
|
||||
int argc, int envc, char *p)
|
||||
{
|
||||
uint32 *argv;
|
||||
uint32 *envp;
|
||||
uint32 *sp;
|
||||
char dummy;
|
||||
|
||||
/* p points to the beginning of the array of arguments;
|
||||
* sp points to the "bottom" of a push down stack.
|
||||
*/
|
||||
|
||||
sp = (uint32*)((-(uint32)sizeof(char*))&(uint32) p);
|
||||
|
||||
/* Place program information on the stack */
|
||||
|
||||
if (prog_load_info)
|
||||
{
|
||||
*sp-- = (uint32)prog_load_info->dspace_size;
|
||||
*sp-- = (uint32)prog_load_info->dspace;
|
||||
*sp-- = (uint32)prog_load_info->ispace;
|
||||
}
|
||||
else
|
||||
{
|
||||
dbg("No program load info provided\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* Place loader information on the stack */
|
||||
|
||||
if (lib_load_info)
|
||||
{
|
||||
*sp-- = (uint32)lib_load_info->dspace_size;
|
||||
*sp-- = (uint32)lib_load_info->dspace;
|
||||
*sp-- = (uint32)lib_load_info->ispace;
|
||||
}
|
||||
else
|
||||
{
|
||||
*sp-- = (uint32)0;
|
||||
*sp-- = (uint32)0;
|
||||
*sp-- = (uint32)0;
|
||||
}
|
||||
|
||||
/* Allocate space on the stack for the envp array contents
|
||||
* (including space for a null terminator).
|
||||
*/
|
||||
|
||||
sp -= envc+1;
|
||||
envp = sp;
|
||||
|
||||
/* Allocate space on the stack for the argv array contents
|
||||
* (including space for a null terminator).
|
||||
*/
|
||||
|
||||
sp -= argc+1;
|
||||
argv = sp;
|
||||
|
||||
/* Put argc on the stack. sp now points to the "top" of the
|
||||
* stack as it will be received by the new task.
|
||||
*/
|
||||
|
||||
*sp-- = (uint32)argc;
|
||||
|
||||
/* Copy argv pointers into the stack frame (terminated with
|
||||
* a null pointer).
|
||||
*/
|
||||
|
||||
prog_load_info->arg_start = (uint32)p;
|
||||
while (argc-->0)
|
||||
{
|
||||
/* Put the address of the beginning of the string */
|
||||
|
||||
*argv++ = (uint32)p;
|
||||
|
||||
/* Search for the end of the string */
|
||||
|
||||
do
|
||||
{
|
||||
dummy = *p++;
|
||||
}
|
||||
while (dummy);
|
||||
}
|
||||
*argv = (uint32)NULL,argv;
|
||||
|
||||
/* Copy envp pointers into the stack frame (terminated with
|
||||
* a null pointer).
|
||||
*/
|
||||
|
||||
prog_load_info->env_start = (uint32)p;
|
||||
while (envc-->0)
|
||||
{
|
||||
/* Put the address of the beginning of the string */
|
||||
|
||||
*envp++ = (uint32)p;
|
||||
|
||||
/* Search for the end of the string */
|
||||
|
||||
do
|
||||
{
|
||||
dummy = *p++;
|
||||
}
|
||||
while (dummy);
|
||||
}
|
||||
*envp = (uint32)NULL;
|
||||
|
||||
prog_load_info->env_end = (uint32)p;
|
||||
|
||||
return (uint32)sp;
|
||||
}
|
||||
|
||||
@@ -0,0 +1,79 @@
|
||||
/****************************************************************************
|
||||
* binfmt/libnxflat/libnxflat_uninit.c
|
||||
*
|
||||
* Copyright (C) 2009 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
#include <sys/types.h>
|
||||
#include <unistd.h>
|
||||
#include <debug.h>
|
||||
#include <errno.h>
|
||||
#include <nuttx/nxflat.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-Processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Constant Data
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_swap32
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_uninit
|
||||
****************************************************************************/
|
||||
|
||||
int nxflat_uninit(struct nxflat_loadinfo_s *loadinfo)
|
||||
{
|
||||
if (loadinfo->filfd >= 0)
|
||||
{
|
||||
close(loadinfo->filfd);
|
||||
}
|
||||
return OK;
|
||||
}
|
||||
|
||||
@@ -0,0 +1,99 @@
|
||||
/****************************************************************************
|
||||
* binfmt/libnxflat/libnxflat_unload.c
|
||||
*
|
||||
* Copyright (C) 2009 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/mman.h>
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <debug.h>
|
||||
|
||||
#include <nuttx/nxflat.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-Processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Constant Data
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_unload
|
||||
*
|
||||
* Description:
|
||||
* This function unloads the object from memory. This essentially
|
||||
* undoes the actions of nxflat_load.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
int nxflat_unload(struct nxflat_loadinfo_s *loadinfo)
|
||||
{
|
||||
/* Reset the contents of the info structure. */
|
||||
|
||||
/* Nothing is allocated */
|
||||
|
||||
loadinfo->alloc_start = 0;
|
||||
loadinfo->alloc_size = 0;
|
||||
|
||||
/* Release the memory segments */
|
||||
|
||||
if (loadinfo->ispace)
|
||||
{
|
||||
munmap((void*)loadinfo->ispace, loadinfo->ispace_size);
|
||||
loadinfo->ispace = 0;
|
||||
}
|
||||
|
||||
if (loadinfo->dspace)
|
||||
{
|
||||
free((void*)loadinfo->dspace);
|
||||
loadinfo->dspace = 0;
|
||||
}
|
||||
|
||||
return OK;
|
||||
}
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/****************************************************************************
|
||||
* nxflat/lib/nxflat_stack.c
|
||||
* binfmt/libnxflat/nxflat_verify.c
|
||||
*
|
||||
* Copyright (C) 2009 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||
@@ -49,20 +49,6 @@
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
#define V_MAP (load_info->vtbl->map)
|
||||
#define V_UNMAP (load_info->vtbl->unmap)
|
||||
#define V_ALLOC (load_info->vtbl->alloc)
|
||||
#define V_FREE (load_info->vtbl->free)
|
||||
#define V_OPEN (load_info->vtbl->open)
|
||||
#define V_READ (load_info->vtbl->read)
|
||||
#define V_CLOSE (load_info->vtbl->close)
|
||||
|
||||
#define XFLT_HDR_SIZE sizeof(struct nxflat_hdr_s)
|
||||
|
||||
#ifndef MAX
|
||||
# define MAX(x,y) ((x) > (y) ? (x) : (y))
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Private Constant Data
|
||||
****************************************************************************/
|
||||
@@ -85,7 +71,7 @@ int nxflat_verifyheader(const struct nxflat_hdr_s *header)
|
||||
|
||||
if (!header)
|
||||
{
|
||||
dbg("NULL NXFLAT header!");
|
||||
bdbg("NULL NXFLAT header!");
|
||||
return -ENOEXEC;
|
||||
}
|
||||
|
||||
@@ -97,7 +83,7 @@ int nxflat_verifyheader(const struct nxflat_hdr_s *header)
|
||||
|
||||
if (strncmp(header->h_magic, "NXFLAT", 4) != 0)
|
||||
{
|
||||
dbg("Unrecognized magic=\"%c%c%c%c\"",
|
||||
bdbg("Unrecognized magic=\"%c%c%c%c\"",
|
||||
header->h_magic[0], header->h_magic[1],
|
||||
header->h_magic[2], header->h_magic[3]);
|
||||
return -ENOEXEC;
|
||||
@@ -108,7 +94,7 @@ int nxflat_verifyheader(const struct nxflat_hdr_s *header)
|
||||
revision = ntohs(header->h_rev);
|
||||
if (revision != NXFLAT_VERSION_CURRENT)
|
||||
{
|
||||
dbg("Unsupported NXFLAT version=%d\n", revision);
|
||||
bdbg("Unsupported NXFLAT version=%d\n", revision);
|
||||
return -ENOEXEC;
|
||||
}
|
||||
return 0;
|
||||
|
||||
+236
@@ -0,0 +1,236 @@
|
||||
/****************************************************************************
|
||||
* binfmt/nxflat.c
|
||||
*
|
||||
* Copyright (C) 2009 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
#include <sys/types.h>
|
||||
|
||||
#include <string.h>
|
||||
#include <nxflat.h>
|
||||
#include <debug.h>
|
||||
#include <errno.h>
|
||||
|
||||
#include <arpa/inet.h>
|
||||
#include <nuttx/binfmt.h>
|
||||
#include <nuttx/nxflat.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Function Prototypes
|
||||
****************************************************************************/
|
||||
|
||||
static int nxflat_loadbinary(struct binary_s *binp);
|
||||
#if defined(CONFIG_DEBUG) && defined(CONFIG_DEBUG_BINFMT)
|
||||
static void nxflat_dumpmemory(void *addr, int nbytes);
|
||||
static void nxflat_dumploadinfo(struct nxflat_loadinfo_s *loadinfo);
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Private Constant Data
|
||||
****************************************************************************/
|
||||
|
||||
static struct binfmt_s g_nxflatbinfmt =
|
||||
{
|
||||
NULL, /* next */
|
||||
nxflat_loadbinary, /* load */
|
||||
};
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nnxflat_dumpmemory
|
||||
****************************************************************************/
|
||||
|
||||
#if defined(CONFIG_DEBUG) && defined(CONFIG_DEBUG_BINFMT)
|
||||
static void nxflat_dumpmemory(void *addr, int nbytes)
|
||||
{
|
||||
ubyte *ptr;
|
||||
|
||||
bdbg(" ADDRESS VALUE\n");
|
||||
for (ptr = (ubyte*)addr; nbytes > 0; ptr += 4, nbytes -= 4)
|
||||
{
|
||||
bdbg(" %p: %02x %02x %02x %02x\n", ptr, ptr[0], ptr[1], ptr[2], ptr[3]);
|
||||
}
|
||||
}
|
||||
#else /* CONFIG_XFLAT_DEBUG */
|
||||
# define nnxflat_dumpmemory(a,n)
|
||||
#endif /* CONFIG_XFLAT_DEBUG */
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_dumploadinfo
|
||||
****************************************************************************/
|
||||
|
||||
#if defined(CONFIG_DEBUG) && defined(CONFIG_DEBUG_BINFMT)
|
||||
static void nxflat_dumploadinfo(struct nxflat_loadinfo_s *loadinfo)
|
||||
{
|
||||
unsigned long dspace_size =
|
||||
NXFLAT_DATA_OFFSET +
|
||||
loadinfo->data_size +
|
||||
loadinfo->bss_size +
|
||||
loadinfo->stack_size;
|
||||
|
||||
bdbg("LOAD_INFO:\n");
|
||||
bdbg(" ISPACE:\n");
|
||||
bdbg(" ispace: %08lx\n", loadinfo->ispace);
|
||||
bdbg(" entry_offset: %08lx\n", loadinfo->entry_offset);
|
||||
bdbg(" ispace_size: %08lx\n", loadinfo->ispace_size);
|
||||
|
||||
bdbg(" DSPACE:\n");
|
||||
bdbg(" dspace: %08lx\n", loadinfo->dspace);
|
||||
bdbg(" (ldso): %08x\n", NXFLAT_DATA_OFFSET);
|
||||
bdbg(" data_size: %08lx\n", loadinfo->data_size);
|
||||
bdbg(" bss_size: %08lx\n", loadinfo->bss_size);
|
||||
bdbg(" (pad): %08lx\n", loadinfo->dspace_size - dspace_size);
|
||||
bdbg(" stack_size: %08lx\n", loadinfo->stack_size);
|
||||
bdbg(" dspace_size: %08lx\n", loadinfo->dspace_size);
|
||||
|
||||
bdbg(" ARGUMENTS:\n");
|
||||
bdbg(" arg_start: %08lx\n", loadinfo->arg_start);
|
||||
bdbg(" env_start: %08lx\n", loadinfo->env_start);
|
||||
bdbg(" env_end: %08lx\n", loadinfo->env_end);
|
||||
|
||||
bdbg(" RELOCS:\n");
|
||||
bdbg(" reloc_start: %08lx\n", loadinfo->reloc_start);
|
||||
bdbg(" reloc_count: %08lx\n", loadinfo->reloc_count);
|
||||
|
||||
bdbg(" HANDLES:\n");
|
||||
bdbg(" filfd: %d\n", loadinfo->filfd);
|
||||
|
||||
bdbg(" NXFLT HEADER:");
|
||||
bdbg(" header: %p\n", loadinfo->header);
|
||||
|
||||
bdbg(" ALLOCATIONS:\n");
|
||||
bdbg(" alloc_start: %08lx\n", loadinfo->alloc_start);
|
||||
bdbg(" alloc_size: %08lx\n", loadinfo->alloc_size);
|
||||
}
|
||||
#else /* CONFIG_XFLAT_DEBUG */
|
||||
# define nxflat_dumploadinfo(i)
|
||||
#endif /* CONFIG_XFLAT_DEBUG */
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_loadbinary
|
||||
*
|
||||
* Description:
|
||||
* Verify that the file is an NXFLAT binary and, if so, load the NXFLAT
|
||||
* binary into memory
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static int nxflat_loadbinary(struct binary_s *binp)
|
||||
{
|
||||
struct nxflat_hdr_s header; /* Just allocated memory */
|
||||
struct nxflat_loadinfo_s loadinfo; /* Contains globals for libnxflat */
|
||||
int ret;
|
||||
|
||||
bvdbg("Loading file: %s\n", binp->filename);
|
||||
|
||||
/* Initialize the xflat library to load the program binary. */
|
||||
|
||||
ret = nxflat_init(binp->filename, &header, &loadinfo);
|
||||
nxflat_dumploadinfo(&loadinfo);
|
||||
if (ret != 0)
|
||||
{
|
||||
bdbg("Failed to initialize for load of NXFLT program: %d\n", ret);
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* Load the program binary */
|
||||
|
||||
ret = nxflat_load(&loadinfo);
|
||||
nxflat_dumploadinfo(&loadinfo);
|
||||
if (ret != 0)
|
||||
{
|
||||
bdbg("Failed to load NXFLT program binary: %d\n", ret);
|
||||
nxflat_uninit(&loadinfo);
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* Return the load information */
|
||||
|
||||
binp->entrypt = (main_t)(loadinfo.ispace + loadinfo.entry_offset);
|
||||
binp->picbase = (void*)loadinfo.dspace;
|
||||
|
||||
bvdbg("ENTRY CODE:\n");
|
||||
nxflat_dumpmemory(binp->entrypt, 16*sizeof(unsigned long));
|
||||
nxflat_uninit(&loadinfo);
|
||||
return OK;
|
||||
}
|
||||
|
||||
/***********************************************************************
|
||||
* Public Functions
|
||||
***********************************************************************/
|
||||
|
||||
/***********************************************************************
|
||||
* Name: nxflat_initialize
|
||||
*
|
||||
* Description:
|
||||
* NXFLAT support is built unconditionally. However, it order to
|
||||
* use this binary format, this function must be called during system
|
||||
* format in order to register the NXFLAT binary format.
|
||||
*
|
||||
***********************************************************************/
|
||||
|
||||
int nxflat_initialize(void)
|
||||
{
|
||||
int ret;
|
||||
|
||||
/* Register ourselves as a binfmt loader */
|
||||
|
||||
bvdbg("Registering NXFLAT\n");
|
||||
ret = register_binfmt(&g_nxflatbinfmt);
|
||||
if (ret != 0)
|
||||
{
|
||||
bdbg("Failed to register binfmt: %d\n", ret);
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: nxflat_uninitialize
|
||||
****************************************************************************/
|
||||
|
||||
void nxflat_uninitialize(void)
|
||||
{
|
||||
unregister_binfmt(&g_nxflatbinfmt);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user