call_prom.c 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. /*
  2. * Copyright (C) 1996-2005 Paul Mackerras.
  3. *
  4. * This program is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU General Public License
  6. * as published by the Free Software Foundation; either version
  7. * 2 of the License, or (at your option) any later version.
  8. */
  9. #include "of1275.h"
  10. #include <stdarg.h>
  11. int call_prom(const char *service, int nargs, int nret, ...)
  12. {
  13. int i;
  14. struct prom_args {
  15. const char *service;
  16. int nargs;
  17. int nret;
  18. unsigned int args[12];
  19. } args;
  20. va_list list;
  21. args.service = service;
  22. args.nargs = nargs;
  23. args.nret = nret;
  24. va_start(list, nret);
  25. for (i = 0; i < nargs; i++)
  26. args.args[i] = va_arg(list, unsigned int);
  27. va_end(list);
  28. for (i = 0; i < nret; i++)
  29. args.args[nargs+i] = 0;
  30. if (of_prom_entry(&args) < 0)
  31. return -1;
  32. return (nret > 0)? args.args[nargs]: 0;
  33. }
  34. int call_prom_ret(const char *service, int nargs, int nret,
  35. unsigned int *rets, ...)
  36. {
  37. int i;
  38. struct prom_args {
  39. const char *service;
  40. int nargs;
  41. int nret;
  42. unsigned int args[12];
  43. } args;
  44. va_list list;
  45. args.service = service;
  46. args.nargs = nargs;
  47. args.nret = nret;
  48. va_start(list, rets);
  49. for (i = 0; i < nargs; i++)
  50. args.args[i] = va_arg(list, unsigned int);
  51. va_end(list);
  52. for (i = 0; i < nret; i++)
  53. args.args[nargs+i] = 0;
  54. if (of_prom_entry(&args) < 0)
  55. return -1;
  56. if (rets != (void *) 0)
  57. for (i = 1; i < nret; ++i)
  58. rets[i-1] = args.args[nargs+i];
  59. return (nret > 0)? args.args[nargs]: 0;
  60. }