mirror of
				https://gitlab.freedesktop.org/pulseaudio/pulseaudio.git
				synced 2025-11-03 09:01:50 -05:00 
			
		
		
		
	split polyplib to multiple modules add some prelimenary documentation add doxygen support git-svn-id: file:///home/lennart/svn/public/pulseaudio/trunk@123 fefdeb5f-60dc-0310-8127-8f9354f1896f
		
			
				
	
	
		
			127 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* $Id$ */
 | 
						|
 | 
						|
/***
 | 
						|
  This file is part of polypaudio.
 | 
						|
 
 | 
						|
  polypaudio is free software; you can redistribute it and/or modify
 | 
						|
  it under the terms of the GNU General Public License as published
 | 
						|
  by the Free Software Foundation; either version 2 of the License,
 | 
						|
  or (at your option) any later version.
 | 
						|
 
 | 
						|
  polypaudio is distributed in the hope that it will be useful, but
 | 
						|
  WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 | 
						|
  General Public License for more details.
 | 
						|
 
 | 
						|
  You should have received a copy of the GNU General Public License
 | 
						|
  along with polypaudio; if not, write to the Free Software
 | 
						|
  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
 | 
						|
  USA.
 | 
						|
***/
 | 
						|
 | 
						|
#ifdef HAVE_CONFIG_H
 | 
						|
#include <config.h>
 | 
						|
#endif
 | 
						|
 | 
						|
#include <stdio.h>
 | 
						|
#include <stdlib.h>
 | 
						|
#include <assert.h>
 | 
						|
#include <string.h>
 | 
						|
 | 
						|
#include "memblock.h"
 | 
						|
#include "xmalloc.h"
 | 
						|
 | 
						|
static unsigned memblock_count = 0, memblock_total = 0;
 | 
						|
 | 
						|
struct pa_memblock *pa_memblock_new(size_t length) {
 | 
						|
    struct pa_memblock *b = pa_xmalloc(sizeof(struct pa_memblock)+length);
 | 
						|
    b->type = PA_MEMBLOCK_APPENDED;
 | 
						|
    b->ref = 1;
 | 
						|
    b->length = length;
 | 
						|
    b->data = b+1;
 | 
						|
    b->free_cb = NULL;
 | 
						|
    memblock_count++;
 | 
						|
    memblock_total += length;
 | 
						|
    return b;
 | 
						|
}
 | 
						|
 | 
						|
struct pa_memblock *pa_memblock_new_fixed(void *d, size_t length) {
 | 
						|
    struct pa_memblock *b = pa_xmalloc(sizeof(struct pa_memblock));
 | 
						|
    b->type = PA_MEMBLOCK_FIXED;
 | 
						|
    b->ref = 1;
 | 
						|
    b->length = length;
 | 
						|
    b->data = d;
 | 
						|
    b->free_cb = NULL;
 | 
						|
    memblock_count++;
 | 
						|
    memblock_total += length;
 | 
						|
    return b;
 | 
						|
}
 | 
						|
 | 
						|
struct pa_memblock *pa_memblock_new_dynamic(void *d, size_t length) {
 | 
						|
    struct pa_memblock *b = pa_xmalloc(sizeof(struct pa_memblock));
 | 
						|
    b->type = PA_MEMBLOCK_DYNAMIC;
 | 
						|
    b->ref = 1;
 | 
						|
    b->length = length;
 | 
						|
    b->data = d;
 | 
						|
    b->free_cb = NULL;
 | 
						|
    memblock_count++;
 | 
						|
    memblock_total += length;
 | 
						|
    return b;
 | 
						|
}
 | 
						|
 | 
						|
struct pa_memblock *pa_memblock_new_user(void *d, size_t length, void (*free_cb)(void *p)) {
 | 
						|
    struct pa_memblock *b;
 | 
						|
    assert(d && length && free_cb);
 | 
						|
    b = pa_xmalloc(sizeof(struct pa_memblock));
 | 
						|
    b->type = PA_MEMBLOCK_USER;
 | 
						|
    b->ref = 1;
 | 
						|
    b->length = length;
 | 
						|
    b->data = d;
 | 
						|
    b->free_cb = free_cb;
 | 
						|
    memblock_count++;
 | 
						|
    memblock_total += length;
 | 
						|
    return b;
 | 
						|
}
 | 
						|
 | 
						|
struct pa_memblock* pa_memblock_ref(struct pa_memblock*b) {
 | 
						|
    assert(b && b->ref >= 1);
 | 
						|
    b->ref++;
 | 
						|
    return b;
 | 
						|
}
 | 
						|
 | 
						|
void pa_memblock_unref(struct pa_memblock*b) {
 | 
						|
    assert(b && b->ref >= 1);
 | 
						|
 | 
						|
    if ((--(b->ref)) == 0) {
 | 
						|
        memblock_count--;
 | 
						|
        memblock_total -= b->length;
 | 
						|
 | 
						|
        if (b->type == PA_MEMBLOCK_USER) {
 | 
						|
            assert(b->free_cb);
 | 
						|
            b->free_cb(b->data);
 | 
						|
        } else if (b->type == PA_MEMBLOCK_DYNAMIC)
 | 
						|
            pa_xfree(b->data);
 | 
						|
 | 
						|
        pa_xfree(b);
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
void pa_memblock_unref_fixed(struct pa_memblock *b) {
 | 
						|
    assert(b && b->ref >= 1 && b->type == PA_MEMBLOCK_FIXED);
 | 
						|
 | 
						|
    if (b->ref == 1)
 | 
						|
        pa_memblock_unref(b);
 | 
						|
    else {
 | 
						|
        b->data = pa_xmemdup(b->data, b->length);
 | 
						|
        b->type = PA_MEMBLOCK_DYNAMIC;
 | 
						|
        b->ref--;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
unsigned pa_memblock_get_count(void) {
 | 
						|
    return memblock_count;
 | 
						|
}
 | 
						|
 | 
						|
unsigned pa_memblock_get_total(void) {
 | 
						|
    return memblock_total;
 | 
						|
}
 |