Skip to content

Commit 1e63810

Browse files
F Ygopherbot
F Y
authored andcommitted
unix: stop counting trailing NUL for abstract addresses starting with NUL
Changes trailing-NUL-counting behavior for abstract addresses starting with the NUL character to be the same as abstract addresses starting with the @ character. For golang/go#63579. Change-Id: I2f26de4bcf614c4635ad188b1afa3d14ebd9a95f Reviewed-on: https://go-review.googlesource.com/c/sys/+/535955 Reviewed-by: Ian Lance Taylor <[email protected]> Auto-Submit: Ian Lance Taylor <[email protected]> Reviewed-by: Benny Siegert <[email protected]> LUCI-TryBot-Result: Go LUCI <[email protected]>
1 parent 1bfbee0 commit 1e63810

File tree

5 files changed

+19
-5
lines changed

5 files changed

+19
-5
lines changed

unix/syscall_aix.go

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -106,7 +106,8 @@ func (sa *SockaddrUnix) sockaddr() (unsafe.Pointer, _Socklen, error) {
106106
if n > 0 {
107107
sl += _Socklen(n) + 1
108108
}
109-
if sa.raw.Path[0] == '@' {
109+
if sa.raw.Path[0] == '@' || (sa.raw.Path[0] == 0 && sl > 3) {
110+
// Check sl > 3 so we don't change unnamed socket behavior.
110111
sa.raw.Path[0] = 0
111112
// Don't count trailing NUL for abstract address.
112113
sl--

unix/syscall_internal_linux_test.go

Lines changed: 11 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -517,7 +517,7 @@ func TestSockaddrUnix_sockaddr(t *testing.T) {
517517
slen: 2, // family (uint16)
518518
},
519519
{
520-
name: "abstract",
520+
name: "abstract_starting_with_at",
521521
sa: &SockaddrUnix{
522522
Name: "@",
523523
},
@@ -526,6 +526,16 @@ func TestSockaddrUnix_sockaddr(t *testing.T) {
526526
},
527527
slen: 3, // family (uint16) + NULL
528528
},
529+
{
530+
name: "abstract_starting_with_null",
531+
sa: &SockaddrUnix{
532+
Name: "\x00",
533+
},
534+
raw: &RawSockaddrUnix{
535+
Family: AF_UNIX,
536+
},
537+
slen: 3, // family (uint16) + NULL
538+
},
529539
{
530540
name: "named",
531541
sa: &SockaddrUnix{

unix/syscall_linux.go

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -417,7 +417,8 @@ func (sa *SockaddrUnix) sockaddr() (unsafe.Pointer, _Socklen, error) {
417417
if n > 0 {
418418
sl += _Socklen(n) + 1
419419
}
420-
if sa.raw.Path[0] == '@' {
420+
if sa.raw.Path[0] == '@' || (sa.raw.Path[0] == 0 && sl > 3) {
421+
// Check sl > 3 so we don't change unnamed socket behavior.
421422
sa.raw.Path[0] = 0
422423
// Don't count trailing NUL for abstract address.
423424
sl--

unix/syscall_solaris.go

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -128,7 +128,8 @@ func (sa *SockaddrUnix) sockaddr() (unsafe.Pointer, _Socklen, error) {
128128
if n > 0 {
129129
sl += _Socklen(n) + 1
130130
}
131-
if sa.raw.Path[0] == '@' {
131+
if sa.raw.Path[0] == '@' || (sa.raw.Path[0] == 0 && sl > 3) {
132+
// Check sl > 3 so we don't change unnamed socket behavior.
132133
sa.raw.Path[0] = 0
133134
// Don't count trailing NUL for abstract address.
134135
sl--

windows/syscall_windows.go

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -970,7 +970,8 @@ func (sa *SockaddrUnix) sockaddr() (unsafe.Pointer, int32, error) {
970970
if n > 0 {
971971
sl += int32(n) + 1
972972
}
973-
if sa.raw.Path[0] == '@' {
973+
if sa.raw.Path[0] == '@' || (sa.raw.Path[0] == 0 && sl > 3) {
974+
// Check sl > 3 so we don't change unnamed socket behavior.
974975
sa.raw.Path[0] = 0
975976
// Don't count trailing NUL for abstract address.
976977
sl--

0 commit comments

Comments
 (0)