Commit 0cd689f5 authored by Aaron Jacobs's avatar Aaron Jacobs

buffer: simplify storage of the header.

parent d1ff915b
...@@ -36,22 +36,10 @@ type OutMessage struct { ...@@ -36,22 +36,10 @@ type OutMessage struct {
// The offset into payload to which we're currently writing. // The offset into payload to which we're currently writing.
payloadOffset int payloadOffset int
header [OutMessageHeaderSize]byte header fusekernel.OutHeader
payload [MaxReadSize]byte payload [MaxReadSize]byte
} }
// Make sure that the header field is aligned correctly for
// fusekernel.OutHeader type punning.
func init() {
a := unsafe.Alignof(OutMessage{})
o := unsafe.Offsetof(OutMessage{}.header)
e := unsafe.Alignof(fusekernel.OutHeader{})
if a%e != 0 || o%e != 0 {
log.Panicf("Bad alignment or offset: %d, %d, need %d", a, o, e)
}
}
// Make sure that the header and payload are contiguous. // Make sure that the header and payload are contiguous.
func init() { func init() {
a := unsafe.Offsetof(OutMessage{}.header) + uintptr(OutMessageHeaderSize) a := unsafe.Offsetof(OutMessage{}.header) + uintptr(OutMessageHeaderSize)
...@@ -73,7 +61,7 @@ func (m *OutMessage) Reset() { ...@@ -73,7 +61,7 @@ func (m *OutMessage) Reset() {
// OutHeader returns a pointer to the header at the start of the message. // OutHeader returns a pointer to the header at the start of the message.
func (m *OutMessage) OutHeader() *fusekernel.OutHeader { func (m *OutMessage) OutHeader() *fusekernel.OutHeader {
return (*fusekernel.OutHeader)(unsafe.Pointer(&m.header)) return &m.header
} }
// Grow grows m's buffer by the given number of bytes, returning a pointer to // Grow grows m's buffer by the given number of bytes, returning a pointer to
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment