Skip to content

Commit

Permalink
Track the major & minor error codes for the library and avoid incr/de…
Browse files Browse the repository at this point in the history
…cr them

Signed-off-by: Quincey Koziol <[email protected]>
  • Loading branch information
qkoziol committed Apr 8, 2024
1 parent c0e3aed commit 4188c90
Show file tree
Hide file tree
Showing 6 changed files with 81 additions and 38 deletions.
35 changes: 31 additions & 4 deletions bin/make_err
Original file line number Diff line number Diff line change
Expand Up @@ -223,6 +223,8 @@ sub create_init ($) {
my $desc; # Description of error message
my $sect_name; # Section of minor error messages
my $sect_desc; # Description of section
my $first_major = 0; # Whether the first major error code was saved
my $first_minor = 0; # Whether the first minor error code was saved

# Rename previous file
# rename "${prefix}${file}", "${prefix}${file}~" or die "unable to make backup";
Expand All @@ -241,12 +243,22 @@ sub create_init ($) {
print HEADER "/* Major error codes */\n";
print HEADER "/*********************/\n\n";
foreach $name (keys %major) {
print HEADER " "x(0*$indent),"assert(${name}_g==(-1));\n";
print HEADER " "x(0*$indent),"assert(${name}_g==H5I_INVALID_HID);\n";
print HEADER " "x(0*$indent),"if((msg = H5E__create_msg(cls, H5E_MAJOR, \"${major{$name}}\"))==NULL)\n";
print HEADER " "x(1*$indent),"HGOTO_ERROR(H5E_ERROR, H5E_CANTINIT, FAIL, \"error message initialization failed\");\n";
print HEADER " "x(0*$indent),"if((${name}_g = H5I_register(H5I_ERROR_MSG, msg, false))<0)\n";
print HEADER " "x(1*$indent),"HGOTO_ERROR(H5E_ERROR, H5E_CANTREGISTER, FAIL, \"can't register error message\");\n";
if ($first_major == 0) {
print HEADER " "x(0*$indent),"\n/* Remember first major error code ID */\n";
print HEADER " "x(0*$indent),"assert(H5E_first_maj_id_g==H5I_INVALID_HID);\n";
print HEADER " "x(0*$indent),"H5E_first_maj_id_g = ${name}_g;\n\n";
$first_major = 1;
}
$last_name = $name;
}
print HEADER " "x(0*$indent),"\n/* Remember last major error code ID */\n";
print HEADER " "x(0*$indent),"assert(H5E_last_maj_id_g==H5I_INVALID_HID);\n";
print HEADER " "x(0*$indent),"H5E_last_maj_id_g = ${last_name}_g;\n\n";

# Iterate over all the minor error sections
print HEADER "\n/*********************/\n";
Expand All @@ -257,13 +269,24 @@ sub create_init ($) {

# Iterate over all the minor errors in each section
for $name ( @{$section_list{$sect_name}}) {
print HEADER " "x(0*$indent),"assert(${name}_g==(-1));\n";
print HEADER " "x(0*$indent),"assert(${name}_g==H5I_INVALID_HID);\n";
print HEADER " "x(0*$indent),"if((msg = H5E__create_msg(cls, H5E_MINOR, \"${minor{$name}}\"))==NULL)\n";
print HEADER " "x(1*$indent),"HGOTO_ERROR(H5E_ERROR, H5E_CANTINIT, FAIL, \"error message initialization failed\");\n";
print HEADER " "x(0*$indent),"if((${name}_g = H5I_register(H5I_ERROR_MSG, msg, true))<0)\n";
print HEADER " "x(1*$indent),"HGOTO_ERROR(H5E_ERROR, H5E_CANTREGISTER, FAIL, \"can't register error message\");\n";

if ($first_minor == 0) {
print HEADER " "x(0*$indent),"\n/* Remember first minor error code ID */\n";
print HEADER " "x(0*$indent),"assert(H5E_first_min_id_g==H5I_INVALID_HID);\n";
print HEADER " "x(0*$indent),"H5E_first_min_id_g = ${name}_g;\n\n";
$first_minor = 1;
}
$last_name = $name;
}
}
print HEADER " "x(0*$indent),"\n/* Remember last minor error code ID */\n";
print HEADER " "x(0*$indent),"assert(H5E_last_min_id_g==H5I_INVALID_HID);\n";
print HEADER " "x(0*$indent),"H5E_last_min_id_g = ${last_name}_g;\n";

print_endprotect(*HEADER, $file);

Expand Down Expand Up @@ -299,7 +322,9 @@ sub create_term ($) {
foreach $name (keys %major) {
print HEADER " "x($indent),"\n${name}_g=";
}
print HEADER " (-1);\n";
print HEADER " H5I_INVALID_HID;\n";
print HEADER " "x(0*$indent),"H5E_first_maj_id_g = H5I_INVALID_HID;\n\n";
print HEADER " "x(0*$indent),"H5E_last_maj_id_g = H5I_INVALID_HID;\n\n";

# Iterate over all the minor error sections
print HEADER "\n/* Reset minor error IDs */\n";
Expand All @@ -311,7 +336,9 @@ sub create_term ($) {
print HEADER " "x($indent),"\n${name}_g=";
}
}
print HEADER " (-1);\n";
print HEADER " H5I_INVALID_HID;\n";
print HEADER " "x(0*$indent),"H5E_first_min_id_g = H5I_INVALID_HID;\n\n";
print HEADER " "x(0*$indent),"H5E_last_min_id_g = H5I_INVALID_HID;\n\n";

print_endprotect(*HEADER, $file);

Expand Down
6 changes: 6 additions & 0 deletions src/H5E.c
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,12 @@ static const H5E_t H5E_err_stack_def = {
NULL /* auto_data */
};

/* First & last major and minor error codes registered by the library */
hid_t H5E_first_maj_id_g = H5I_INVALID_HID;
hid_t H5E_last_maj_id_g = H5I_INVALID_HID;
hid_t H5E_first_min_id_g = H5I_INVALID_HID;
hid_t H5E_last_min_id_g = H5I_INVALID_HID;

/*****************************/
/* Library Private Variables */
/*****************************/
Expand Down
62 changes: 33 additions & 29 deletions src/H5Eint.c
Original file line number Diff line number Diff line change
Expand Up @@ -734,22 +734,26 @@ H5E__push_stack(H5E_t *estack, const char *file, const char *func, unsigned line

if (estack->nused < H5E_NSLOTS) {
/* Increment the IDs to indicate that they are used in this stack */
if (H5I_inc_ref_noherr(cls_id, false) < 0)
HGOTO_DONE(FAIL);
/* Note: don't waste time incrementing library internal error IDs */
if (cls_id != H5E_ERR_CLS_g)
if (H5I_inc_ref_noherr(cls_id, false) < 0)
HGOTO_DONE(FAIL);
estack->slot[estack->nused].cls_id = cls_id;
if (H5I_inc_ref_noherr(maj_id, false) < 0)
HGOTO_DONE(FAIL);
if (maj_id < H5E_first_maj_id_g || maj_id > H5E_last_maj_id_g)
if (H5I_inc_ref_noherr(maj_id, false) < 0)
HGOTO_DONE(FAIL);
estack->slot[estack->nused].maj_num = maj_id;
if (H5I_inc_ref_noherr(min_id, false) < 0)
HGOTO_DONE(FAIL);
if (min_id < H5E_first_min_id_g || min_id > H5E_last_min_id_g)
if (H5I_inc_ref_noherr(min_id, false) < 0)
HGOTO_DONE(FAIL);
estack->slot[estack->nused].min_num = min_id;
/* The 'func' & 'file' strings are statically allocated (by the compiler)
* there's no need to duplicate them.
*/
estack->slot[estack->nused].func_name = func;
estack->slot[estack->nused].file_name = file;
estack->slot[estack->nused].line = line;
if (NULL == (estack->slot[estack->nused].desc = H5MM_xstrdup(desc)))
if (NULL == (estack->slot[estack->nused].desc = strdup(desc)))
HGOTO_DONE(FAIL);
estack->nused++;
} /* end if */
Expand Down Expand Up @@ -787,12 +791,16 @@ H5E__clear_entries(H5E_t *estack, size_t nentries)

/* Decrement the IDs to indicate that they are no longer used by this stack */
/* (In reverse order that they were incremented, so that reference counts work well) */
if (H5I_dec_ref(error->min_num) < 0)
HGOTO_ERROR(H5E_ERROR, H5E_CANTDEC, FAIL, "unable to decrement ref count on error message");
if (H5I_dec_ref(error->maj_num) < 0)
HGOTO_ERROR(H5E_ERROR, H5E_CANTDEC, FAIL, "unable to decrement ref count on error message");
if (H5I_dec_ref(error->cls_id) < 0)
HGOTO_ERROR(H5E_ERROR, H5E_CANTDEC, FAIL, "unable to decrement ref count on error class");
/* Note: don't decrement library internal error IDs, since they weren't incremented */
if (error->min_num < H5E_first_min_id_g || error->min_num > H5E_last_min_id_g)
if (H5I_dec_ref(error->min_num) < 0)
HGOTO_ERROR(H5E_ERROR, H5E_CANTDEC, FAIL, "unable to decrement ref count on error message");
if (error->maj_num < H5E_first_maj_id_g || error->maj_num > H5E_last_maj_id_g)
if (H5I_dec_ref(error->maj_num) < 0)
HGOTO_ERROR(H5E_ERROR, H5E_CANTDEC, FAIL, "unable to decrement ref count on error message");
if (error->cls_id != H5E_ERR_CLS_g)
if (H5I_dec_ref(error->cls_id) < 0)
HGOTO_ERROR(H5E_ERROR, H5E_CANTDEC, FAIL, "unable to decrement ref count on error class");

/* Release strings */
/* The 'func' & 'file' strings are statically allocated (by the compiler)
Expand Down Expand Up @@ -884,32 +892,28 @@ H5E__pop(H5E_t *estack, size_t count)
*-------------------------------------------------------------------------
*/
herr_t
H5E_dump_api_stack(bool is_api)
H5E_dump_api_stack(void)
{
H5E_t *estack = H5E__get_my_stack();
herr_t ret_value = SUCCEED; /* Return value */

FUNC_ENTER_NOAPI_NOERR

/* Only dump the error stack during an API call */
if (is_api) {
H5E_t *estack = H5E__get_my_stack();

assert(estack);
assert(estack);

#ifdef H5_NO_DEPRECATED_SYMBOLS
if (estack->auto_op.func2)
(void)((estack->auto_op.func2)(H5E_DEFAULT, estack->auto_data));
#else /* H5_NO_DEPRECATED_SYMBOLS */
if (estack->auto_op.vers == 1) {
if (estack->auto_op.func1)
(void)((estack->auto_op.func1)(estack->auto_data));
} /* end if */
else {
if (estack->auto_op.func2)
(void)((estack->auto_op.func2)(H5E_DEFAULT, estack->auto_data));
#else /* H5_NO_DEPRECATED_SYMBOLS */
if (estack->auto_op.vers == 1) {
if (estack->auto_op.func1)
(void)((estack->auto_op.func1)(estack->auto_data));
} /* end if */
else {
if (estack->auto_op.func2)
(void)((estack->auto_op.func2)(H5E_DEFAULT, estack->auto_data));
} /* end else */
} /* end else */
#endif /* H5_NO_DEPRECATED_SYMBOLS */
} /* end if */

FUNC_LEAVE_NOAPI(ret_value)
} /* end H5E_dump_api_stack() */
6 changes: 6 additions & 0 deletions src/H5Epkg.h
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,12 @@ struct H5E_t {
H5_DLLVAR H5E_t H5E_stack_g[1];
#endif

/* First & last major and minor error codes registered by the library */
H5_DLLVAR hid_t H5E_first_maj_id_g;
H5_DLLVAR hid_t H5E_last_maj_id_g;
H5_DLLVAR hid_t H5E_first_min_id_g;
H5_DLLVAR hid_t H5E_last_min_id_g;

/******************************/
/* Package Private Prototypes */
/******************************/
Expand Down
2 changes: 1 addition & 1 deletion src/H5Eprivate.h
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,6 @@ H5_DLL herr_t H5E_init(void);
H5_DLL herr_t H5E_printf_stack(H5E_t *estack, const char *file, const char *func, unsigned line, hid_t cls_id,
hid_t maj_id, hid_t min_id, const char *fmt, ...) H5_ATTR_FORMAT(printf, 8, 9);
H5_DLL herr_t H5E_clear_stack(H5E_t *estack);
H5_DLL herr_t H5E_dump_api_stack(bool is_api);
H5_DLL herr_t H5E_dump_api_stack(void);

#endif /* H5Eprivate_H */
8 changes: 4 additions & 4 deletions src/H5private.h
Original file line number Diff line number Diff line change
Expand Up @@ -1672,7 +1672,7 @@ H5_DLL herr_t H5CX_pop(bool update_dxpl_props);
api_ctx_pushed = false; \
} \
if (H5_UNLIKELY(err_occurred)) \
(void)H5E_dump_api_stack(true); \
(void)H5E_dump_api_stack(); \
H5_API_UNLOCK \
return (ret_value); \
} \
Expand All @@ -1685,7 +1685,7 @@ H5_DLL herr_t H5CX_pop(bool update_dxpl_props);
FUNC_LEAVE_API_COMMON(ret_value); \
H5_POP_FUNC \
if (H5_UNLIKELY(err_occurred)) \
(void)H5E_dump_api_stack(TRUE); \
(void)H5E_dump_api_stack(); \
H5_API_UNLOCK \
return (ret_value); \
} \
Expand All @@ -1698,7 +1698,7 @@ H5_DLL herr_t H5CX_pop(bool update_dxpl_props);
} /*end scope from end of FUNC_ENTER*/ \
FUNC_LEAVE_API_COMMON(ret_value); \
if (H5_UNLIKELY(err_occurred)) \
(void)H5E_dump_api_stack(true); \
(void)H5E_dump_api_stack(); \
H5_API_UNLOCK \
return (ret_value); \
} \
Expand All @@ -1722,7 +1722,7 @@ H5_DLL herr_t H5CX_pop(bool update_dxpl_props);
; \
} /*end scope from end of FUNC_ENTER*/ \
if (H5_UNLIKELY(err_occurred)) \
(void)H5E_dump_api_stack(true); \
(void)H5E_dump_api_stack(); \
H5_API_UNLOCK \
return (ret_value); \
} \
Expand Down

0 comments on commit 4188c90

Please sign in to comment.