From: Tom Thorogood Date: Fri, 12 Mar 2021 13:57:30 +0000 (+1030) Subject: archive/zip: fix character device handling in fileModeToUnixMode X-Git-Tag: go1.17beta1~865 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=dac136f87b9d5fdda9b5c33dfa0f94dc8c9880c7;p=gostls13.git archive/zip: fix character device handling in fileModeToUnixMode The switch case for fs.ModeDevice can only be reached for block devices while character devices match fs.ModeDevice | fs.ModeCharDevice. This would cause character devices to wrongly be reported as regular files. This bug has existed since the switch was first introduced in CL 5624048. Change-Id: Icdbedb015e5376b385b3115d2e4574daa052f796 Reviewed-on: https://go-review.googlesource.com/c/go/+/300891 Run-TryBot: Ian Lance Taylor TryBot-Result: Go Bot Reviewed-by: Ian Lance Taylor Trust: Emmanuel Odeke --- diff --git a/src/archive/zip/struct.go b/src/archive/zip/struct.go index 4dd29f35fa..3dc0c50122 100644 --- a/src/archive/zip/struct.go +++ b/src/archive/zip/struct.go @@ -341,11 +341,9 @@ func fileModeToUnixMode(mode fs.FileMode) uint32 { case fs.ModeSocket: m = s_IFSOCK case fs.ModeDevice: - if mode&fs.ModeCharDevice != 0 { - m = s_IFCHR - } else { - m = s_IFBLK - } + m = s_IFBLK + case fs.ModeDevice | fs.ModeCharDevice: + m = s_IFCHR } if mode&fs.ModeSetuid != 0 { m |= s_ISUID diff --git a/src/archive/zip/writer_test.go b/src/archive/zip/writer_test.go index 5985144e5c..3fa8bef055 100644 --- a/src/archive/zip/writer_test.go +++ b/src/archive/zip/writer_test.go @@ -57,6 +57,18 @@ var writeTests = []WriteTest{ Method: Deflate, Mode: 0755 | fs.ModeSymlink, }, + { + Name: "device", + Data: []byte("device file"), + Method: Deflate, + Mode: 0755 | fs.ModeDevice, + }, + { + Name: "chardevice", + Data: []byte("char device file"), + Method: Deflate, + Mode: 0755 | fs.ModeDevice | fs.ModeCharDevice, + }, } func TestWriter(t *testing.T) {