1 /* 2 * Misc and compatibility things 3 * Copyright (c) by Jaroslav Kysela <perex@suse.cz> 4 * 5 * 6 * This program is free software; you can redistribute it and/or modify 7 * it under the terms of the GNU General Public License as published by 8 * the Free Software Foundation; either version 2 of the License, or 9 * (at your option) any later version. 10 * 11 * This program is distributed in the hope that it will be useful, 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 * GNU General Public License for more details. 15 * 16 * You should have received a copy of the GNU General Public License 17 * along with this program; if not, write to the Free Software 18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 19 * 20 */ 21 22 #include <sound/driver.h> 23 #include <linux/init.h> 24 #include <linux/sched.h> 25 #include <linux/time.h> 26 #include <linux/ioport.h> 27 #include <sound/core.h> 28 29 void release_and_free_resource(struct resource *res) 30 { 31 if (res) { 32 release_resource(res); 33 kfree(res); 34 } 35 } 36 37 #ifdef CONFIG_SND_VERBOSE_PRINTK 38 void snd_verbose_printk(const char *file, int line, const char *format, ...) 39 { 40 va_list args; 41 42 if (format[0] == '<' && format[1] >= '0' && format[1] <= '9' && format[2] == '>') { 43 char tmp[] = "<0>"; 44 tmp[1] = format[1]; 45 printk("%sALSA %s:%d: ", tmp, file, line); 46 format += 3; 47 } else { 48 printk("ALSA %s:%d: ", file, line); 49 } 50 va_start(args, format); 51 vprintk(format, args); 52 va_end(args); 53 } 54 #endif 55 56 #if defined(CONFIG_SND_DEBUG) && defined(CONFIG_SND_VERBOSE_PRINTK) 57 void snd_verbose_printd(const char *file, int line, const char *format, ...) 58 { 59 va_list args; 60 61 if (format[0] == '<' && format[1] >= '0' && format[1] <= '9' && format[2] == '>') { 62 char tmp[] = "<0>"; 63 tmp[1] = format[1]; 64 printk("%sALSA %s:%d: ", tmp, file, line); 65 format += 3; 66 } else { 67 printk(KERN_DEBUG "ALSA %s:%d: ", file, line); 68 } 69 va_start(args, format); 70 vprintk(format, args); 71 va_end(args); 72 73 } 74 #endif 75