diff options
author | Sverker Eriksson <[email protected]> | 2019-04-09 16:32:06 +0200 |
---|---|---|
committer | Sverker Eriksson <[email protected]> | 2019-04-09 17:04:38 +0200 |
commit | ef44ba53defa0002ca6b12a786bd2d3555b0bb7b (patch) | |
tree | 85b848dce49edd113194fb592ebbed5068d86598 /lib/erl_interface/src/encode/encode_pid.c | |
parent | d293c3ff700c1a0992a32dc3da9ae18964893c23 (diff) | |
download | otp-ef44ba53defa0002ca6b12a786bd2d3555b0bb7b.tar.gz otp-ef44ba53defa0002ca6b12a786bd2d3555b0bb7b.tar.bz2 otp-ef44ba53defa0002ca6b12a786bd2d3555b0bb7b.zip |
Revert "erl_interface: Remove old encoding of pid,port,refs"
This reverts commit 78ea501bcc84bd8bd49da97e514c1c3b20682d86.
Diffstat (limited to 'lib/erl_interface/src/encode/encode_pid.c')
-rw-r--r-- | lib/erl_interface/src/encode/encode_pid.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/lib/erl_interface/src/encode/encode_pid.c b/lib/erl_interface/src/encode/encode_pid.c index 0dfdb16372..d14746b40f 100644 --- a/lib/erl_interface/src/encode/encode_pid.c +++ b/lib/erl_interface/src/encode/encode_pid.c @@ -25,6 +25,7 @@ int ei_encode_pid(char *buf, int *index, const erlang_pid *p) { char* s = buf + *index; + const char tag = (p->creation > 3) ? ERL_NEW_PID_EXT : ERL_PID_EXT; ++(*index); /* skip ERL_PID_EXT */ if (ei_encode_atom_len_as(buf, index, p->node, strlen(p->node), @@ -32,17 +33,21 @@ int ei_encode_pid(char *buf, int *index, const erlang_pid *p) return -1; if (buf) { - put8(s, ERL_NEW_PID_EXT); + put8(s, tag); s = buf + *index; /* now the integers */ put32be(s,p->num & 0x7fff); /* 15 bits */ put32be(s,p->serial & 0x1fff); /* 13 bits */ - put32be(s, p->creation); /* 32 bits */ + if (tag == ERL_PID_EXT) { + put8(s,(p->creation & 0x03)); /* 2 bits */ + } else { + put32be(s, p->creation); /* 32 bits */ + } } - *index += 4 + 4 + 4; + *index += 4 + 4 + (tag == ERL_PID_EXT ? 1 : 4); return 0; } |