home *** CD-ROM | disk | FTP | other *** search
/ Geek Gadgets 1 / ADE-1.bin / ade-dist / ixemul-45.0-src.tgz / tar.out / contrib / ixemul / library / getrlimit.c < prev    next >
C/C++ Source or Header  |  1996-09-28  |  2KB  |  87 lines

  1. /*
  2.  *  This file is part of ixemul.library for the Amiga.
  3.  *  Copyright (C) 1991, 1992  Markus M. Wild
  4.  *
  5.  *  This library is free software; you can redistribute it and/or
  6.  *  modify it under the terms of the GNU Library General Public
  7.  *  License as published by the Free Software Foundation; either
  8.  *  version 2 of the License, or (at your option) any later version.
  9.  *
  10.  *  This library is distributed in the hope that it will be useful,
  11.  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  12.  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  13.  *  Library General Public License for more details.
  14.  *
  15.  *  You should have received a copy of the GNU Library General Public
  16.  *  License along with this library; if not, write to the Free
  17.  *  Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  18.  *
  19.  *  getrlimit.c,v 1.1.1.1 1994/04/04 04:30:24 amiga Exp
  20.  *
  21.  *  getrlimit.c,v
  22.  * Revision 1.1.1.1  1994/04/04  04:30:24  amiga
  23.  * Initial CVS check in.
  24.  *
  25.  *  Revision 1.1  1992/05/14  19:55:40  mwild
  26.  *  Initial revision
  27.  *
  28.  */
  29.  
  30. #define _KERNEL
  31. #include "ixemul.h"
  32. #include "kprintf.h"
  33. #include <sys/time.h>
  34. #include <sys/resource.h>
  35.  
  36. int
  37. getrlimit(int resource, struct rlimit *rlp)
  38. {
  39.   struct Task *task = (struct Task *) FindTask (0);
  40.  
  41.   if (resource < RLIMIT_CPU || resource > RLIMIT_RSS || !rlp)
  42.     {
  43.       errno = EINVAL;
  44.       KPRINTF (("&errno = %lx, errno = %ld\n", &errno, errno));
  45.       return -1;
  46.     }
  47.  
  48.   if (task->tc_Node.ln_Type == NT_PROCESS)
  49.     {
  50.       /* in that case, we're not a task, but a process */
  51.       struct Process *proc = (struct Process *)task;
  52.     
  53.       switch (resource)
  54.         {
  55.         case RLIMIT_CPU:
  56.     case RLIMIT_FSIZE:
  57.     case RLIMIT_CORE:
  58.     case RLIMIT_RSS:
  59.         case RLIMIT_DATA:
  60.       rlp->rlim_cur = rlp->rlim_max = RLIM_INFINITY;
  61.       break;
  62.     case RLIMIT_STACK:
  63.       rlp->rlim_cur = rlp->rlim_max = proc->pr_StackSize;
  64.       break;
  65.     }
  66.     }    
  67.   else
  68.     {
  69.       /* so this is a task, and it has the stack-data somewhere else.. */
  70.       switch (resource)
  71.         {
  72.         case RLIMIT_CPU:
  73.     case RLIMIT_FSIZE:
  74.     case RLIMIT_CORE:
  75.     case RLIMIT_RSS:
  76.         case RLIMIT_DATA:
  77.       rlp->rlim_cur = rlp->rlim_max = RLIM_INFINITY;
  78.       break;
  79.     case RLIMIT_STACK:
  80.       rlp->rlim_cur = rlp->rlim_max = task->tc_SPUpper-task->tc_SPLower;
  81.       break;
  82.     }
  83.     }
  84.  
  85.   return 0;
  86. }
  87.