/* * section and descriptor parser * * Copyright (C) 2005 Kenneth Aafloy (kenneth@linuxtv.org) * Copyright (C) 2005 Andrew de Quincey (adq_dvb@lidskialf.net) * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */ #ifndef _UCSI_MPEG_FMC_DESCRIPTOR #define _UCSI_MPEG_FMC_DESCRIPTOR 1 #ifdef __cplusplus extern "C" { #endif #include #include /** * mpeg_fmc_descriptor structure. */ struct mpeg_fmc_descriptor { struct descriptor d; /* struct mpeg_flex_mux muxes[] */ } __ucsi_packed; /** * An entry in the muxes field of an mpeg_fmc_descriptor structure. */ struct mpeg_flex_mux { uint16_t es_id; uint8_t flex_mux_channel; } __ucsi_packed; /** * Process an mpeg_fmc_descriptor structure. * * @param d Generic descriptor structure. * @return Pointer to an mpeg_fmc_descriptor structure, or NULL on error. */ static inline struct mpeg_fmc_descriptor* mpeg_fmc_descriptor_codec(struct descriptor* d) { uint8_t* buf = (uint8_t*) d + 2; int pos = 0; int len = d->len; if (len % sizeof(struct mpeg_flex_mux)) return NULL; while(pos < len) { bswap16(buf+pos); pos += sizeof(struct mpeg_flex_mux); } return (struct mpeg_fmc_descriptor*) d; } /** * Convenience iterator for the muxes field of an mpeg_fmc_descriptor structure. * * @param d Generic descriptor structure. * @param pos Variable holding a pointer to the the current entry within the muxes field. */ #define mpeg_fmc_descriptor_muxes_for_each(d, pos) \ for ((pos) = mpeg_fmc_descriptor_muxes_first(d); \ (pos); \ (pos) = mpeg_fmc_descriptor_muxes_next(d, pos)) /******************************** PRIVATE CODE ********************************/ static inline struct mpeg_flex_mux* mpeg_fmc_descriptor_muxes_first(struct mpeg_fmc_descriptor *d) { if (d->d.len < sizeof(struct mpeg_flex_mux)) return NULL; return (struct mpeg_flex_mux *) ((uint8_t*) d + sizeof(struct mpeg_fmc_descriptor)); } static inline struct mpeg_flex_mux* mpeg_fmc_descriptor_muxes_next(struct mpeg_fmc_descriptor *d, struct mpeg_flex_mux *pos) { uint8_t *end = (uint8_t*) d + 2 + d->d.len; uint8_t *next = (uint8_t *) pos + sizeof(struct mpeg_flex_mux); if (next >= end) return NULL; return (struct mpeg_flex_mux *) next; } #ifdef __cplusplus } #endif #endif '>16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
/* $Id: debug.c,v 1.6 2003/10/05 17:58:50 reinelt Exp $
 *
 * debug() and error() functions
 *
 * Copyright 1999, 2000 Michael Reinelt <reinelt@eunet.at>
 *
 * This file is part of LCD4Linux.
 *
 * LCD4Linux 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, or (at your option)
 * any later version.
 *
 * LCD4Linux 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 this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 *
 * $Log: debug.c,v $
 * Revision 1.6  2003/10/05 17:58:50  reinelt
 * libtool junk; copyright messages cleaned up
 *
 * Revision 1.5  2003/08/24 05:17:58  reinelt
 * liblcd4linux patch from Patrick Schemitz
 *
 * Revision 1.4  2003/08/08 06:58:06  reinelt
 * improved forking
 *
 * Revision 1.3  2001/03/12 12:39:36  reinelt
 *
 * reworked autoconf a lot: drivers may be excluded, #define's went to config.h
 *
 * Revision 1.2  2001/03/09 13:08:11  ltoetsch
 * Added Text driver
 *
 * Revision 1.1  2000/11/28 20:20:38  reinelt
 *
 * added debug.c
 * things like that should not hapen. debug.c exists for a few months now, but was never added to CVS. Shit happens....
 *
 */

/* 
 * exported functions:
 *
 * message (level, format, ...)
 *   passes the arguments to vsprintf() and
 *   writes the resulting string either to stdout
 *   or syslog.
 *   this function should not be called directly,
 *   but the macros info(), debug() and error()
 *
 */

#include "config.h"

#include <stdlib.h>
#include <stdio.h>
#include <stdarg.h>
#include <syslog.h>

#include "debug.h"

int running_foreground = 0;
int running_background = 0;

int verbose_level = 0;

void message (int level, const char *format, ...)
{
  va_list ap;
  char buffer[256];
  static int log_open=0;

  if (level>verbose_level) return;

  va_start(ap, format);
  (void) vsnprintf(buffer, sizeof(buffer), format, ap);
  va_end(ap);
  
  if (!running_background) {
#ifdef WITH_TEXT
    extern int curs_err(char *);
    if (!curs_err(buffer))
#endif      
      fprintf (level?stdout:stderr, "%s\n", buffer);
  }
  
  if (running_foreground)
    return;
  
  if (!log_open) {
    openlog ("LCD4Linux", LOG_PID, LOG_USER);
    log_open=1;
  }
  
  switch (level) {
  case 0:
    syslog (LOG_ERR, "%s", buffer);
    break;
  case 1:
    syslog (LOG_INFO, "%s", buffer);
    break;
  default:
    syslog (LOG_DEBUG, "%s", buffer);
  }
}