* elf.c (bfd_elf_get_elf_syms): Don't leak memory on error.
[binutils.git] / bfd / nlm.c
blob5cb8ac12e1cdf89f9a6fa8260162c5e8f2ed6bc3
1 /* NLM (NetWare Loadable Module) executable support for BFD.
2 Copyright 1993, 1994, 2001, 2002, 2003, 2005, 2007
3 Free Software Foundation, Inc.
5 This file is part of BFD, the Binary File Descriptor library.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
20 MA 02110-1301, USA. */
22 #include "sysdep.h"
23 #include "bfd.h"
24 #include "libbfd.h"
25 #include "libnlm.h"
27 /* Make an NLM object. We just need to allocate the backend
28 information. */
30 bfd_boolean
31 nlm_mkobject (bfd * abfd)
33 bfd_size_type amt = sizeof (struct nlm_obj_tdata);
35 nlm_tdata (abfd) = bfd_zalloc (abfd, amt);
36 if (nlm_tdata (abfd) == NULL)
37 return FALSE;
39 if (nlm_architecture (abfd) != bfd_arch_unknown)
40 bfd_default_set_arch_mach (abfd, nlm_architecture (abfd),
41 nlm_machine (abfd));
43 /* Since everything is done at close time, do we need any initialization ? */
44 return TRUE;
47 /* Set the architecture and machine for an NLM object. */
49 bfd_boolean
50 nlm_set_arch_mach (bfd * abfd,
51 enum bfd_architecture arch,
52 unsigned long machine)
54 bfd_default_set_arch_mach (abfd, arch, machine);
55 return arch == nlm_architecture (abfd);