aboutsummaryrefslogtreecommitdiffstats
path: root/camel/camel-debug.c
diff options
context:
space:
mode:
Diffstat (limited to 'camel/camel-debug.c')
-rw-r--r--camel/camel-debug.c258
1 files changed, 0 insertions, 258 deletions
diff --git a/camel/camel-debug.c b/camel/camel-debug.c
deleted file mode 100644
index da97e0ba8f..0000000000
--- a/camel/camel-debug.c
+++ /dev/null
@@ -1,258 +0,0 @@
-/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- *
- *
- * Author: Michael Zucchi <notzed@ximian.com>
- *
- * Copyright 2004 Novell Inc. (www.novell.com)
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of version 2 of the GNU General Public
- * License as published by the Free Software Foundation.
- *
- * This program 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307
- * USA
- */
-
-#include <stdlib.h>
-#include <string.h>
-#include <stdio.h>
-
-#include <pthread.h>
-
-#include "camel-debug.h"
-
-int camel_verbose_debug;
-
-static GHashTable *debug_table = NULL;
-
-/**
- * camel_debug_init:
- * @void:
- *
- * Init camel debug. Maintain legacy CAMEL_VERBOSE_DEBUG as well as the
- * new CAMEL_DEBUG based environment variable interfaces.
- *
- * CAMEL_VERBOSE_DEBUG is set to a number to turn debug on.
- *
- * CAMEL_DEBUG is set to a comma separated list of modules to debug.
- * The modules can contain module-specific specifiers after a ':', or
- * just act as a wildcard for the module or even specifier. e.g. 'imap'
- * for imap debug, or 'imap:folder' for imap folder debug. Additionaly,
- * ':folder' can be used for a wildcard for any folder operations.
- **/
-void camel_debug_init(void)
-{
- char *d;
-
- d = getenv("CAMEL_VERBOSE_DEBUG");
- if (d)
- camel_verbose_debug = atoi(d);
-
- d = g_strdup(getenv("CAMEL_DEBUG"));
- if (d) {
- char *p;
-
- debug_table = g_hash_table_new(g_str_hash, g_str_equal);
- p = d;
- while (*p) {
- while (*p && *p != ',')
- p++;
- if (*p)
- *p++ = 0;
- g_hash_table_insert(debug_table, d, d);
- d = p;
- }
-
- if (g_hash_table_lookup(debug_table, "all"))
- camel_verbose_debug = 1;
- }
-}
-
-/**
- * camel_debug:
- * @mode:
- *
- * Check to see if a debug mode is activated. @mode takes one of two forms,
- * a fully qualified 'module:target', or a wildcard 'module' name. It
- * returns a boolean to indicate if the module or module and target is
- * currently activated for debug output.
- *
- * Return value:
- **/
-gboolean camel_debug(const char *mode)
-{
- if (camel_verbose_debug)
- return TRUE;
-
- if (debug_table) {
- char *colon;
- char *fallback;
-
- if (g_hash_table_lookup(debug_table, mode))
- return TRUE;
-
- /* Check for fully qualified debug */
- colon = strchr(mode, ':');
- if (colon) {
- fallback = g_alloca(strlen(mode)+1);
- strcpy(fallback, mode);
- colon = (colon-mode) + fallback;
- /* Now check 'module[:*]' */
- *colon = 0;
- if (g_hash_table_lookup(debug_table, fallback))
- return TRUE;
- /* Now check ':subsystem' */
- *colon = ':';
- if (g_hash_table_lookup(debug_table, colon))
- return TRUE;
- }
- }
-
- return FALSE;
-}
-
-static pthread_mutex_t debug_lock = PTHREAD_MUTEX_INITIALIZER;
-/**
- * camel_debug_start:
- * @mode:
- *
- * Start debug output for a given mode, used to make sure debug output
- * is output atomically and not interspersed with unrelated stuff.
- *
- * Return value: Returns true if mode is set, and in which case, you must
- * call debug_end when finished any screen output.
- **/
-gboolean
-camel_debug_start(const char *mode)
-{
- if (camel_debug(mode)) {
- pthread_mutex_lock(&debug_lock);
- printf("Thread %lx >\n", pthread_self());
- return TRUE;
- }
-
- return FALSE;
-}
-
-/**
- * camel_debug_end:
- *
- * Call this when you're done with your debug output. If and only if
- * you called camel_debug_start, and if it returns TRUE.
- **/
-void
-camel_debug_end(void)
-{
- printf("< %lx >\n", pthread_self());
- pthread_mutex_unlock(&debug_lock);
-}
-
-#if 0
-#include <sys/debugreg.h>
-
-static unsigned
-i386_length_and_rw_bits (int len, enum target_hw_bp_type type)
-{
- unsigned rw;
-
- switch (type)
- {
- case hw_execute:
- rw = DR_RW_EXECUTE;
- break;
- case hw_write:
- rw = DR_RW_WRITE;
- break;
- case hw_read: /* x86 doesn't support data-read watchpoints */
- case hw_access:
- rw = DR_RW_READ;
- break;
-#if 0
- case hw_io_access: /* not yet supported */
- rw = DR_RW_IORW;
- break;
-#endif
- default:
- internal_error (__FILE__, __LINE__, "\
-Invalid hw breakpoint type %d in i386_length_and_rw_bits.\n", (int)type);
- }
-
- switch (len)
- {
- case 1:
- return (DR_LEN_1 | rw);
- case 2:
- return (DR_LEN_2 | rw);
- case 4:
- return (DR_LEN_4 | rw);
- case 8:
- if (TARGET_HAS_DR_LEN_8)
- return (DR_LEN_8 | rw);
- default:
- internal_error (__FILE__, __LINE__, "\
-Invalid hw breakpoint length %d in i386_length_and_rw_bits.\n", len);
- }
-}
-
-#define I386_DR_SET_RW_LEN(i,rwlen) \
- do { \
- dr_control_mirror &= ~(0x0f << (DR_CONTROL_SHIFT+DR_CONTROL_SIZE*(i))); \
- dr_control_mirror |= ((rwlen) << (DR_CONTROL_SHIFT+DR_CONTROL_SIZE*(i))); \
- } while (0)
-
-#define I386_DR_LOCAL_ENABLE(i) \
- dr_control_mirror |= (1 << (DR_LOCAL_ENABLE_SHIFT + DR_ENABLE_SIZE * (i)))
-
-
-#define set_dr(regnum, val) \
- __asm__("movl %0,%%db" #regnum \
- : /* no output */ \
- :"r" (val))
-
-#define get_dr(regnum, val) \
- __asm__("movl %%db" #regnum ", %0" \
- :"=r" (val))
-
-/* fine idea, but it doesn't work, crashes in get_dr :-/ */
-void
-camel_debug_hwatch(int wp, void *addr)
-{
- guint32 control, rw;
-
- g_assert(wp <= DR_LASTADDR);
- g_assert(sizeof(addr) == 4);
-
- get_dr(7, control);
- /* set watch mode + size */
- rw = DR_RW_WRITE | DR_LEN_4;
- control &= ~(((1<<DR_CONTROL_SIZE)-1) << (DR_CONTROL_SHIFT+DR_CONTROL_SIZE * wp));
- control |= rw << (DR_CONTROL_SHIFT + DR_CONTROL_SIZE*wp);
- /* set watch enable */
- control |= ( 1<< (DR_LOCAL_ENABLE_SHIFT + DR_ENABLE_SIZE * wp));
- control |= DR_LOCAL_SLOWDOWN;
- control &= ~DR_CONTROL_RESERVED;
-
- switch (wp) {
- case 0:
- set_dr(0, addr);
- break;
- case 1:
- set_dr(1, addr);
- break;
- case 2:
- set_dr(2, addr);
- break;
- case 3:
- set_dr(3, addr);
- break;
- }
- set_dr(7, control);
-}
-
-#endif