vfs: check userland buffers before reading them.
[haiku.git] / src / add-ons / kernel / drivers / audio / ac97 / auich / util.c
blob6d9c4ad56d872282a40369d1f60c1954078ef0f9
1 /*
2 * BeOS Driver for Intel ICH AC'97 Link interface
4 * Copyright (c) 2002, Marcus Overhagen <marcus@overhagen.de>
6 * All rights reserved.
7 * Redistribution and use in source and binary forms, with or without modification,
8 * are permitted provided that the following conditions are met:
10 * - Redistributions of source code must retain the above copyright notice,
11 * this list of conditions and the following disclaimer.
12 * - Redistributions in binary form must reproduce the above copyright notice,
13 * this list of conditions and the following disclaimer in the documentation
14 * and/or other materials provided with the distribution.
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
20 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
24 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
25 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 #include <Errors.h>
29 #include <OS.h>
30 #include <string.h>
32 //#define DEBUG 2
34 #include "debug.h"
35 #include "util.h"
37 spinlock slock = B_SPINLOCK_INITIALIZER;
39 uint32 round_to_pagesize(uint32 size);
42 cpu_status
43 lock(void)
45 cpu_status status = disable_interrupts();
46 acquire_spinlock(&slock);
47 return status;
51 void
52 unlock(cpu_status status)
54 release_spinlock(&slock);
55 restore_interrupts(status);
59 uint32
60 round_to_pagesize(uint32 size)
62 return (size + B_PAGE_SIZE - 1) & ~(B_PAGE_SIZE - 1);
66 area_id
67 alloc_mem(phys_addr_t *phy, void **log, size_t size, const char *name)
69 physical_entry pe;
70 void * logadr;
71 area_id area;
72 status_t rv;
74 LOG(("allocating %d bytes for %s\n",size,name));
76 size = round_to_pagesize(size);
77 area = create_area(name, &logadr, B_ANY_KERNEL_ADDRESS, size,
78 B_32_BIT_CONTIGUOUS, B_READ_AREA | B_WRITE_AREA);
79 // TODO: The rest of the code doesn't deal correctly with physical
80 // addresses > 4 GB, so we have to force 32 bit addresses here.
81 if (area < B_OK) {
82 PRINT(("couldn't allocate area %s\n", name));
83 return B_ERROR;
85 rv = get_memory_map(logadr, size, &pe, 1);
86 if (rv < B_OK) {
87 delete_area(area);
88 PRINT(("couldn't map %s\n",name));
89 return B_ERROR;
91 memset(logadr, 0, size);
92 if (log)
93 *log = logadr;
94 if (phy)
95 *phy = pe.address;
96 LOG(("area = %d, size = %d, log = %#08X, phy = %#08X\n", area, size, logadr,
97 pe.address));
98 return area;
102 area_id
103 map_mem(void **log, phys_addr_t phy, size_t size, const char *name)
105 uint32 offset;
106 phys_addr_t phyadr;
107 void *mapadr;
108 area_id area;
110 LOG(("mapping physical address %p with %#x bytes for %s\n",phy,size,name));
112 offset = (uint32)phy & (B_PAGE_SIZE - 1);
113 phyadr = phy - offset;
114 size = round_to_pagesize(size + offset);
115 area = map_physical_memory(name, phyadr, size, B_ANY_KERNEL_ADDRESS,
116 0, &mapadr);
117 *log = mapadr + offset;
119 LOG(("physical = %p, logical = %p, offset = %#x, phyadr = %p, mapadr = %p, size = %#x, area = %#x\n",
120 phy, *log, offset, phyadr, mapadr, size, area));
122 return area;