diff options
author | Sverker Eriksson <[email protected]> | 2015-09-01 19:53:40 +0200 |
---|---|---|
committer | Sverker Eriksson <[email protected]> | 2015-09-01 20:01:30 +0200 |
commit | a22b5ba19193e3f39129fadd20d375f6cc3f8529 (patch) | |
tree | 98c67cd1faf69ddf19e1c3f76f536b09aebb553a /erts/emulator/beam/erl_term.h | |
parent | 99d3e9c5b2569169d2f5fefd67898d2533e5a83d (diff) | |
download | otp-a22b5ba19193e3f39129fadd20d375f6cc3f8529.tar.gz otp-a22b5ba19193e3f39129fadd20d375f6cc3f8529.tar.bz2 otp-a22b5ba19193e3f39129fadd20d375f6cc3f8529.zip |
erts: Fix bug when tracing with 'process_dump'
If the process stack contained a match state
the print function would crash the vm as it was not
recognized by tag_val_def().
Add new MATCHSTATE_DEF returned by tag_val_def().
All other callers either ignore it or has a default
clause to handle invalid terms.
Diffstat (limited to 'erts/emulator/beam/erl_term.h')
-rw-r--r-- | erts/emulator/beam/erl_term.h | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/erts/emulator/beam/erl_term.h b/erts/emulator/beam/erl_term.h index 37014ccf94..1b6bb27395 100644 --- a/erts/emulator/beam/erl_term.h +++ b/erts/emulator/beam/erl_term.h @@ -1095,6 +1095,9 @@ _ET_DECLARE_CHECKED(Uint,y_reg_index,Uint) #define FLOAT_DEF 0xe #define BIG_DEF 0xf #define SMALL_DEF 0x10 +#define MATCHSTATE_DEF 0x11 /* not a "real" term */ + +#define FIRST_VACANT_TAG_DEF 0x12 #if ET_DEBUG extern unsigned tag_val_def_debug(Wterm, const char*, unsigned); |