view src/unexsol2-6.c @ 5187:b51c2079ec8e

Be much more careful about resizing a string argument, #'fill 2010-04-03 Aidan Kehoe <kehoea@parhasard.net> * fns.c (Ffill): Be much more careful about resizing a string argument, update pointers to within the string data that may have been relocated with the string resize. Fixes a test hang reported by Vin Shelton; thanks, Vin.
author Aidan Kehoe <kehoea@parhasard.net>
date Sat, 03 Apr 2010 15:27:32 +0100
parents 04bc9d2f42c7
children 308d34e9f07d
line wrap: on
line source

/* Unexec function for Solaris 2.x
   Copyright (C) 1994 Sun Microsystems, Inc.

This file is part of XEmacs.

XEmacs is free software; you can redistribute it and/or modify it
under the terms of the GNU General Public License as published by the
Free Software Foundation; either version 2, or (at your option) any
later version.

XEmacs is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
for more details.

You should have received a copy of the GNU General Public License
along with XEmacs; see the file COPYING.  If not, write to
the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.  */

/* Synched up with: Not in FSF. */

#include <stdlib.h>
#include <stdio.h>
#include <dlfcn.h>
#include "compiler.h"

int unexec (char *new_name, char *old_name, unsigned int data_start,
	    unsigned int bss_start, unsigned int entry_address);
int
unexec (char *new_name, char *UNUSED (old_name),
	unsigned int UNUSED (data_start), unsigned int UNUSED (bss_start),
	unsigned int UNUSED (entry_address))
{
  if (dldump (0, new_name, RTLD_MEMORY) != 0)
    {
      fprintf (stderr, "unexec(): dldump(%s): %s \n",
	       new_name, dlerror());
      exit (1);
    }

  return 0;
}