home *** CD-ROM | disk | FTP | other *** search
/ Tools / WinSN5.0Ver.iso / NETSCAP.50 / WIN1998.ZIP / ns / nsprpub / pr / src / md / windows / w16mem.c < prev    next >
Encoding:
C/C++ Source or Header  |  1998-04-08  |  1.8 KB  |  67 lines

  1. /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
  2. /*
  3.  * The contents of this file are subject to the Netscape Public License
  4.  * Version 1.0 (the "NPL"); you may not use this file except in
  5.  * compliance with the NPL.  You may obtain a copy of the NPL at
  6.  * http://www.mozilla.org/NPL/
  7.  * 
  8.  * Software distributed under the NPL is distributed on an "AS IS" basis,
  9.  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
  10.  * for the specific language governing rights and limitations under the
  11.  * NPL.
  12.  * 
  13.  * The Initial Developer of this code under the NPL is Netscape
  14.  * Communications Corporation.  Portions created by Netscape are
  15.  * Copyright (C) 1998 Netscape Communications Corporation.  All Rights
  16.  * Reserved.
  17.  */
  18.  
  19. /*******************************************************************
  20. ** w16mem.c -- Implement memory segment functions.
  21. **
  22. ** 
  23. ********************************************************************
  24. */
  25. #include "primpl.h"
  26.  
  27.  
  28. /*
  29. **    Allocate a new memory segment.
  30. **    
  31. **    Return the segment's access rights and size.  
  32. */
  33. PRStatus _MD_AllocSegment(PRSegment *seg, PRUint32 size, void *vaddr)
  34. {
  35.     PR_ASSERT(seg != 0);
  36.     PR_ASSERT(size != 0);
  37.     PR_ASSERT(vaddr == 0);
  38.  
  39.     /*    
  40.     ** Take the actual memory for the segment out of our Figment heap.
  41.     */
  42.  
  43.     seg->vaddr = (char *)malloc(size);
  44.  
  45.     if (seg->vaddr == NULL) {
  46.         return PR_FAILURE;
  47.     }
  48.  
  49.     seg->access = PR_SEGMENT_RDWR;    
  50.     seg->size = size;    
  51.  
  52.     return PR_SUCCESS;
  53. } /* --- end _MD_AllocSegment() --- */
  54.  
  55.  
  56. /*
  57. **    Free previously allocated memory segment.
  58. */
  59. void _MD_FreeSegment(PRSegment *seg)
  60. {
  61.     PR_ASSERT((seg->flags & _PR_SEG_VM) == 0);
  62.  
  63.     if (seg->vaddr != NULL)
  64.         free( seg->vaddr );
  65.     return;
  66. } /* --- end _MD_FreeSegment() --- */
  67.