Commit f33780d3 authored by Peter Tiedemann's avatar Peter Tiedemann Committed by Jeff Garzik

claw/lcs/netiucv: check s390dbf level before sprints

additional check of s390dbf level results in better performance
if the default low debugging level is active.
Signed-off-by: default avatarPeter Tiedemann <ptiedem@de.ibm.com>
Signed-off-by: default avatarUrsula Braun <braunu@de.ibm.com>
Signed-off-by: default avatarJeff Garzik <jeff@garzik.org>
parent 164b0fb1
...@@ -114,11 +114,20 @@ do { \ ...@@ -114,11 +114,20 @@ do { \
debug_event(claw_dbf_##name,level,(void*)(addr),len); \ debug_event(claw_dbf_##name,level,(void*)(addr),len); \
} while (0) } while (0)
/* Allow to sort out low debug levels early to avoid wasted sprints */
static inline int claw_dbf_passes(debug_info_t *dbf_grp, int level)
{
return (level <= dbf_grp->level);
}
#define CLAW_DBF_TEXT_(level,name,text...) \ #define CLAW_DBF_TEXT_(level,name,text...) \
do { \ do { \
sprintf(debug_buffer, text); \ if (claw_dbf_passes(claw_dbf_##name, level)) { \
debug_text_event(claw_dbf_##name,level, debug_buffer);\ sprintf(debug_buffer, text); \
} while (0) debug_text_event(claw_dbf_##name, level, \
debug_buffer); \
} \
} while (0)
/******************************************************* /*******************************************************
* Define Control Blocks * * Define Control Blocks *
......
...@@ -16,11 +16,19 @@ do { \ ...@@ -16,11 +16,19 @@ do { \
debug_event(lcs_dbf_##name,level,(void*)(addr),len); \ debug_event(lcs_dbf_##name,level,(void*)(addr),len); \
} while (0) } while (0)
/* Allow to sort out low debug levels early to avoid wasted sprints */
static inline int lcs_dbf_passes(debug_info_t *dbf_grp, int level)
{
return (level <= dbf_grp->level);
}
#define LCS_DBF_TEXT_(level,name,text...) \ #define LCS_DBF_TEXT_(level,name,text...) \
do { \ do { \
sprintf(debug_buffer, text); \ if (lcs_dbf_passes(lcs_dbf_##name, level)) { \
debug_text_event(lcs_dbf_##name,level, debug_buffer);\ sprintf(debug_buffer, text); \
} while (0) debug_text_event(lcs_dbf_##name, level, debug_buffer); \
} \
} while (0)
/** /**
* sysfs related stuff * sysfs related stuff
......
...@@ -97,12 +97,22 @@ MODULE_DESCRIPTION ("Linux for S/390 IUCV network driver"); ...@@ -97,12 +97,22 @@ MODULE_DESCRIPTION ("Linux for S/390 IUCV network driver");
DECLARE_PER_CPU(char[256], iucv_dbf_txt_buf); DECLARE_PER_CPU(char[256], iucv_dbf_txt_buf);
#define IUCV_DBF_TEXT_(name,level,text...) \ /* Allow to sort out low debug levels early to avoid wasted sprints */
do { \ static inline int iucv_dbf_passes(debug_info_t *dbf_grp, int level)
char* iucv_dbf_txt_buf = get_cpu_var(iucv_dbf_txt_buf); \ {
sprintf(iucv_dbf_txt_buf, text); \ return (level <= dbf_grp->level);
debug_text_event(iucv_dbf_##name,level,iucv_dbf_txt_buf); \ }
put_cpu_var(iucv_dbf_txt_buf); \
#define IUCV_DBF_TEXT_(name, level, text...) \
do { \
if (iucv_dbf_passes(iucv_dbf_##name, level)) { \
char* iucv_dbf_txt_buf = \
get_cpu_var(iucv_dbf_txt_buf); \
sprintf(iucv_dbf_txt_buf, text); \
debug_text_event(iucv_dbf_##name, level, \
iucv_dbf_txt_buf); \
put_cpu_var(iucv_dbf_txt_buf); \
} \
} while (0) } while (0)
#define IUCV_DBF_SPRINTF(name,level,text...) \ #define IUCV_DBF_SPRINTF(name,level,text...) \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment