nlm.c 1.7 KB

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