binfmt_register.c 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. /****************************************************************************
  2. * binfmt/binfmt_register.c
  3. *
  4. * Licensed to the Apache Software Foundation (ASF) under one or more
  5. * contributor license agreements. See the NOTICE file distributed with
  6. * this work for additional information regarding copyright ownership. The
  7. * ASF licenses this file to you under the Apache License, Version 2.0 (the
  8. * "License"); you may not use this file except in compliance with the
  9. * License. You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing, software
  14. * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  15. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  16. * License for the specific language governing permissions and limitations
  17. * under the License.
  18. *
  19. ****************************************************************************/
  20. /****************************************************************************
  21. * Included Files
  22. ****************************************************************************/
  23. #include <nuttx/config.h>
  24. #include <string.h>
  25. #include <sched.h>
  26. #include <debug.h>
  27. #include <errno.h>
  28. #include <nuttx/binfmt/binfmt.h>
  29. #include "binfmt.h"
  30. #ifndef CONFIG_BINFMT_DISABLE
  31. /****************************************************************************
  32. * Public Functions
  33. ****************************************************************************/
  34. /****************************************************************************
  35. * Name: register_binfmt
  36. *
  37. * Description:
  38. * Register a loader for a binary format
  39. *
  40. * Returned Value:
  41. * This is a NuttX internal function so it follows the convention that
  42. * 0 (OK) is returned on success and a negated errno is returned on
  43. * failure.
  44. *
  45. ****************************************************************************/
  46. int register_binfmt(FAR struct binfmt_s *binfmt)
  47. {
  48. if (binfmt)
  49. {
  50. /* Add the new binary format handler to the head of the list of
  51. * handlers
  52. */
  53. sched_lock();
  54. binfmt->next = g_binfmts;
  55. g_binfmts = binfmt;
  56. sched_unlock();
  57. return OK;
  58. }
  59. return -EINVAL;
  60. }
  61. #endif /* CONFIG_BINFMT_DISABLE */