# HG changeset patch # User jprovino # Date 1335988026 14400 # Node ID 6f0612ea55ce1bba1d93e79dbccdbd5b5e2ff88e # Parent d6c393b0164b62e34ce95a01ac0f1051ed8f3ece# Parent 973046802b6fea1c550217f90ecdaf14be778afb Merge diff -r d6c393b0164b -r 6f0612ea55ce src/os/solaris/vm/attachListener_solaris.cpp --- a/src/os/solaris/vm/attachListener_solaris.cpp Wed Apr 25 15:06:51 2012 -0700 +++ b/src/os/solaris/vm/attachListener_solaris.cpp Wed May 02 15:47:06 2012 -0400 @@ -336,7 +336,9 @@ // Return 0 (success) + file descriptor, or non-0 (error) if (res == 0) { door_desc_t desc; - desc.d_attributes = DOOR_DESCRIPTOR; + // DOOR_RELEASE flag makes sure fd is closed after passing it to + // the client. See door_return(3DOOR) man page. + desc.d_attributes = DOOR_DESCRIPTOR | DOOR_RELEASE; desc.d_data.d_desc.d_descriptor = return_fd; door_return((char*)&res, sizeof(res), &desc, 1); } else {