/* * ES1370 Haiku Driver for ES1370 audio * * Copyright 2002-2007, Haiku, Inc. * Distributed under the terms of the MIT License. * * Authors: * Marcus Overhagen, marcus@overhagen.de * Jerome Duval, jerome.duval@free.fr */ #include #include #include #include #include #include #include "debug.h" #include "es1370.h" #if DEBUG > 0 static const char * logfile="/boot/home/es1370.log"; static sem_id loglock; #endif void debug_printf(const char *text,...); void log_printf(const char *text,...); void log_create(void); void debug_printf(const char *text,...) { char buf[1024]; va_list ap; va_start(ap,text); vsprintf(buf,text,ap); va_end(ap); dprintf(DRIVER_NAME ": %s",buf); } void log_create() { #if DEBUG > 0 int fd = open(logfile, O_WRONLY | O_CREAT | O_TRUNC, 0666); const char *text = DRIVER_NAME ", " VERSION "\n"; loglock = create_sem(1,"logfile sem"); write(fd,text,strlen(text)); close(fd); #endif } void log_printf(const char *text,...) { #if DEBUG > 0 int fd; char buf[1024]; va_list ap; va_start(ap,text); vsprintf(buf,text,ap); va_end(ap); dprintf(DRIVER_NAME ": %s",buf); acquire_sem(loglock); fd = open(logfile, O_WRONLY | O_APPEND); write(fd,buf,strlen(buf)); close(fd); release_sem(loglock); #if DEBUG > 1 snooze(150000); #endif #endif }