aboutsummaryrefslogtreecommitdiffstats
path: root/lib/erl_interface/src/encode/encode_pid.c
diff options
context:
space:
mode:
authorSverker Eriksson <[email protected]>2019-04-09 16:32:06 +0200
committerSverker Eriksson <[email protected]>2019-04-09 17:04:38 +0200
commitef44ba53defa0002ca6b12a786bd2d3555b0bb7b (patch)
tree85b848dce49edd113194fb592ebbed5068d86598 /lib/erl_interface/src/encode/encode_pid.c
parentd293c3ff700c1a0992a32dc3da9ae18964893c23 (diff)
downloadotp-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.c11
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;
}