// automatically generated by stateify. package tcp import ( "gvisor.dev/gvisor/pkg/state" "gvisor.dev/gvisor/pkg/tcpip/buffer" ) func (a *acceptQueue) StateTypeName() string { return "pkg/tcpip/transport/tcp.acceptQueue" } func (a *acceptQueue) StateFields() []string { return []string{ "endpoints", "pendingEndpoints", "capacity", } } func (a *acceptQueue) beforeSave() {} // +checklocksignore func (a *acceptQueue) StateSave(stateSinkObject state.Sink) { a.beforeSave() var endpointsValue []*endpoint endpointsValue = a.saveEndpoints() stateSinkObject.SaveValue(0, endpointsValue) stateSinkObject.Save(1, &a.pendingEndpoints) stateSinkObject.Save(2, &a.capacity) } func (a *acceptQueue) afterLoad() {} // +checklocksignore func (a *acceptQueue) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(1, &a.pendingEndpoints) stateSourceObject.Load(2, &a.capacity) stateSourceObject.LoadValue(0, new([]*endpoint), func(y interface{}) { a.loadEndpoints(y.([]*endpoint)) }) } func (c *cubicState) StateTypeName() string { return "pkg/tcpip/transport/tcp.cubicState" } func (c *cubicState) StateFields() []string { return []string{ "TCPCubicState", "numCongestionEvents", "s", } } func (c *cubicState) beforeSave() {} // +checklocksignore func (c *cubicState) StateSave(stateSinkObject state.Sink) { c.beforeSave() stateSinkObject.Save(0, &c.TCPCubicState) stateSinkObject.Save(1, &c.numCongestionEvents) stateSinkObject.Save(2, &c.s) } func (c *cubicState) afterLoad() {} // +checklocksignore func (c *cubicState) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &c.TCPCubicState) stateSourceObject.Load(1, &c.numCongestionEvents) stateSourceObject.Load(2, &c.s) } func (s *SACKInfo) StateTypeName() string { return "pkg/tcpip/transport/tcp.SACKInfo" } func (s *SACKInfo) StateFields() []string { return []string{ "Blocks", "NumBlocks", } } func (s *SACKInfo) beforeSave() {} // +checklocksignore func (s *SACKInfo) StateSave(stateSinkObject state.Sink) { s.beforeSave() stateSinkObject.Save(0, &s.Blocks) stateSinkObject.Save(1, &s.NumBlocks) } func (s *SACKInfo) afterLoad() {} // +checklocksignore func (s *SACKInfo) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &s.Blocks) stateSourceObject.Load(1, &s.NumBlocks) } func (r *ReceiveErrors) StateTypeName() string { return "pkg/tcpip/transport/tcp.ReceiveErrors" } func (r *ReceiveErrors) StateFields() []string { return []string{ "ReceiveErrors", "SegmentQueueDropped", "ChecksumErrors", "ListenOverflowSynDrop", "ListenOverflowAckDrop", "ZeroRcvWindowState", "WantZeroRcvWindow", } } func (r *ReceiveErrors) beforeSave() {} // +checklocksignore func (r *ReceiveErrors) StateSave(stateSinkObject state.Sink) { r.beforeSave() stateSinkObject.Save(0, &r.ReceiveErrors) stateSinkObject.Save(1, &r.SegmentQueueDropped) stateSinkObject.Save(2, &r.ChecksumErrors) stateSinkObject.Save(3, &r.ListenOverflowSynDrop) stateSinkObject.Save(4, &r.ListenOverflowAckDrop) stateSinkObject.Save(5, &r.ZeroRcvWindowState) stateSinkObject.Save(6, &r.WantZeroRcvWindow) } func (r *ReceiveErrors) afterLoad() {} // +checklocksignore func (r *ReceiveErrors) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &r.ReceiveErrors) stateSourceObject.Load(1, &r.SegmentQueueDropped) stateSourceObject.Load(2, &r.ChecksumErrors) stateSourceObject.Load(3, &r.ListenOverflowSynDrop) stateSourceObject.Load(4, &r.ListenOverflowAckDrop) stateSourceObject.Load(5, &r.ZeroRcvWindowState) stateSourceObject.Load(6, &r.WantZeroRcvWindow) } func (s *SendErrors) StateTypeName() string { return "pkg/tcpip/transport/tcp.SendErrors" } func (s *SendErrors) StateFields() []string { return []string{ "SendErrors", "SegmentSendToNetworkFailed", "SynSendToNetworkFailed", "Retransmits", "FastRetransmit", "Timeouts", } } func (s *SendErrors) beforeSave() {} // +checklocksignore func (s *SendErrors) StateSave(stateSinkObject state.Sink) { s.beforeSave() stateSinkObject.Save(0, &s.SendErrors) stateSinkObject.Save(1, &s.SegmentSendToNetworkFailed) stateSinkObject.Save(2, &s.SynSendToNetworkFailed) stateSinkObject.Save(3, &s.Retransmits) stateSinkObject.Save(4, &s.FastRetransmit) stateSinkObject.Save(5, &s.Timeouts) } func (s *SendErrors) afterLoad() {} // +checklocksignore func (s *SendErrors) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &s.SendErrors) stateSourceObject.Load(1, &s.SegmentSendToNetworkFailed) stateSourceObject.Load(2, &s.SynSendToNetworkFailed) stateSourceObject.Load(3, &s.Retransmits) stateSourceObject.Load(4, &s.FastRetransmit) stateSourceObject.Load(5, &s.Timeouts) } func (s *Stats) StateTypeName() string { return "pkg/tcpip/transport/tcp.Stats" } func (s *Stats) StateFields() []string { return []string{ "SegmentsReceived", "SegmentsSent", "FailedConnectionAttempts", "ReceiveErrors", "ReadErrors", "SendErrors", "WriteErrors", } } func (s *Stats) beforeSave() {} // +checklocksignore func (s *Stats) StateSave(stateSinkObject state.Sink) { s.beforeSave() stateSinkObject.Save(0, &s.SegmentsReceived) stateSinkObject.Save(1, &s.SegmentsSent) stateSinkObject.Save(2, &s.FailedConnectionAttempts) stateSinkObject.Save(3, &s.ReceiveErrors) stateSinkObject.Save(4, &s.ReadErrors) stateSinkObject.Save(5, &s.SendErrors) stateSinkObject.Save(6, &s.WriteErrors) } func (s *Stats) afterLoad() {} // +checklocksignore func (s *Stats) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &s.SegmentsReceived) stateSourceObject.Load(1, &s.SegmentsSent) stateSourceObject.Load(2, &s.FailedConnectionAttempts) stateSourceObject.Load(3, &s.ReceiveErrors) stateSourceObject.Load(4, &s.ReadErrors) stateSourceObject.Load(5, &s.SendErrors) stateSourceObject.Load(6, &s.WriteErrors) } func (s *sndQueueInfo) StateTypeName() string { return "pkg/tcpip/transport/tcp.sndQueueInfo" } func (s *sndQueueInfo) StateFields() []string { return []string{ "TCPSndBufState", } } func (s *sndQueueInfo) beforeSave() {} // +checklocksignore func (s *sndQueueInfo) StateSave(stateSinkObject state.Sink) { s.beforeSave() stateSinkObject.Save(0, &s.TCPSndBufState) } func (s *sndQueueInfo) afterLoad() {} // +checklocksignore func (s *sndQueueInfo) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &s.TCPSndBufState) } func (r *rcvQueueInfo) StateTypeName() string { return "pkg/tcpip/transport/tcp.rcvQueueInfo" } func (r *rcvQueueInfo) StateFields() []string { return []string{ "TCPRcvBufState", "rcvQueue", } } func (r *rcvQueueInfo) beforeSave() {} // +checklocksignore func (r *rcvQueueInfo) StateSave(stateSinkObject state.Sink) { r.beforeSave() stateSinkObject.Save(0, &r.TCPRcvBufState) stateSinkObject.Save(1, &r.rcvQueue) } func (r *rcvQueueInfo) afterLoad() {} // +checklocksignore func (r *rcvQueueInfo) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &r.TCPRcvBufState) stateSourceObject.LoadWait(1, &r.rcvQueue) } func (e *endpoint) StateTypeName() string { return "pkg/tcpip/transport/tcp.endpoint" } func (e *endpoint) StateFields() []string { return []string{ "TCPEndpointStateInner", "TransportEndpointInfo", "DefaultSocketOptionsHandler", "waiterQueue", "uniqueID", "hardError", "lastError", "rcvQueueInfo", "rcvMemUsed", "ownedByUser", "state", "boundNICID", "ttl", "isConnectNotified", "portFlags", "boundBindToDevice", "boundPortFlags", "boundDest", "effectiveNetProtos", "workerRunning", "workerCleanup", "recentTSTime", "shutdownFlags", "tcpRecovery", "sack", "delay", "scoreboard", "segmentQueue", "userMSS", "maxSynRetries", "windowClamp", "sndQueueInfo", "cc", "keepalive", "userTimeout", "deferAccept", "acceptQueue", "rcv", "snd", "connectingAddress", "amss", "sendTOS", "gso", "stats", "tcpLingerTimeout", "closed", "txHash", "owner", "ops", "lastOutOfWindowAckTime", } } // +checklocksignore func (e *endpoint) StateSave(stateSinkObject state.Sink) { e.beforeSave() var stateValue EndpointState stateValue = e.saveState() stateSinkObject.SaveValue(10, stateValue) stateSinkObject.Save(0, &e.TCPEndpointStateInner) stateSinkObject.Save(1, &e.TransportEndpointInfo) stateSinkObject.Save(2, &e.DefaultSocketOptionsHandler) stateSinkObject.Save(3, &e.waiterQueue) stateSinkObject.Save(4, &e.uniqueID) stateSinkObject.Save(5, &e.hardError) stateSinkObject.Save(6, &e.lastError) stateSinkObject.Save(7, &e.rcvQueueInfo) stateSinkObject.Save(8, &e.rcvMemUsed) stateSinkObject.Save(9, &e.ownedByUser) stateSinkObject.Save(11, &e.boundNICID) stateSinkObject.Save(12, &e.ttl) stateSinkObject.Save(13, &e.isConnectNotified) stateSinkObject.Save(14, &e.portFlags) stateSinkObject.Save(15, &e.boundBindToDevice) stateSinkObject.Save(16, &e.boundPortFlags) stateSinkObject.Save(17, &e.boundDest) stateSinkObject.Save(18, &e.effectiveNetProtos) stateSinkObject.Save(19, &e.workerRunning) stateSinkObject.Save(20, &e.workerCleanup) stateSinkObject.Save(21, &e.recentTSTime) stateSinkObject.Save(22, &e.shutdownFlags) stateSinkObject.Save(23, &e.tcpRecovery) stateSinkObject.Save(24, &e.sack) stateSinkObject.Save(25, &e.delay) stateSinkObject.Save(26, &e.scoreboard) stateSinkObject.Save(27, &e.segmentQueue) stateSinkObject.Save(28, &e.userMSS) stateSinkObject.Save(29, &e.maxSynRetries) stateSinkObject.Save(30, &e.windowClamp) stateSinkObject.Save(31, &e.sndQueueInfo) stateSinkObject.Save(32, &e.cc) stateSinkObject.Save(33, &e.keepalive) stateSinkObject.Save(34, &e.userTimeout) stateSinkObject.Save(35, &e.deferAccept) stateSinkObject.Save(36, &e.acceptQueue) stateSinkObject.Save(37, &e.rcv) stateSinkObject.Save(38, &e.snd) stateSinkObject.Save(39, &e.connectingAddress) stateSinkObject.Save(40, &e.amss) stateSinkObject.Save(41, &e.sendTOS) stateSinkObject.Save(42, &e.gso) stateSinkObject.Save(43, &e.stats) stateSinkObject.Save(44, &e.tcpLingerTimeout) stateSinkObject.Save(45, &e.closed) stateSinkObject.Save(46, &e.txHash) stateSinkObject.Save(47, &e.owner) stateSinkObject.Save(48, &e.ops) stateSinkObject.Save(49, &e.lastOutOfWindowAckTime) } // +checklocksignore func (e *endpoint) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &e.TCPEndpointStateInner) stateSourceObject.Load(1, &e.TransportEndpointInfo) stateSourceObject.Load(2, &e.DefaultSocketOptionsHandler) stateSourceObject.LoadWait(3, &e.waiterQueue) stateSourceObject.Load(4, &e.uniqueID) stateSourceObject.Load(5, &e.hardError) stateSourceObject.Load(6, &e.lastError) stateSourceObject.Load(7, &e.rcvQueueInfo) stateSourceObject.Load(8, &e.rcvMemUsed) stateSourceObject.Load(9, &e.ownedByUser) stateSourceObject.Load(11, &e.boundNICID) stateSourceObject.Load(12, &e.ttl) stateSourceObject.Load(13, &e.isConnectNotified) stateSourceObject.Load(14, &e.portFlags) stateSourceObject.Load(15, &e.boundBindToDevice) stateSourceObject.Load(16, &e.boundPortFlags) stateSourceObject.Load(17, &e.boundDest) stateSourceObject.Load(18, &e.effectiveNetProtos) stateSourceObject.Load(19, &e.workerRunning) stateSourceObject.Load(20, &e.workerCleanup) stateSourceObject.Load(21, &e.recentTSTime) stateSourceObject.Load(22, &e.shutdownFlags) stateSourceObject.Load(23, &e.tcpRecovery) stateSourceObject.Load(24, &e.sack) stateSourceObject.Load(25, &e.delay) stateSourceObject.Load(26, &e.scoreboard) stateSourceObject.LoadWait(27, &e.segmentQueue) stateSourceObject.Load(28, &e.userMSS) stateSourceObject.Load(29, &e.maxSynRetries) stateSourceObject.Load(30, &e.windowClamp) stateSourceObject.Load(31, &e.sndQueueInfo) stateSourceObject.Load(32, &e.cc) stateSourceObject.Load(33, &e.keepalive) stateSourceObject.Load(34, &e.userTimeout) stateSourceObject.Load(35, &e.deferAccept) stateSourceObject.Load(36, &e.acceptQueue) stateSourceObject.LoadWait(37, &e.rcv) stateSourceObject.LoadWait(38, &e.snd) stateSourceObject.Load(39, &e.connectingAddress) stateSourceObject.Load(40, &e.amss) stateSourceObject.Load(41, &e.sendTOS) stateSourceObject.Load(42, &e.gso) stateSourceObject.Load(43, &e.stats) stateSourceObject.Load(44, &e.tcpLingerTimeout) stateSourceObject.Load(45, &e.closed) stateSourceObject.Load(46, &e.txHash) stateSourceObject.Load(47, &e.owner) stateSourceObject.Load(48, &e.ops) stateSourceObject.Load(49, &e.lastOutOfWindowAckTime) stateSourceObject.LoadValue(10, new(EndpointState), func(y interface{}) { e.loadState(y.(EndpointState)) }) stateSourceObject.AfterLoad(e.afterLoad) } func (k *keepalive) StateTypeName() string { return "pkg/tcpip/transport/tcp.keepalive" } func (k *keepalive) StateFields() []string { return []string{ "idle", "interval", "count", "unacked", } } func (k *keepalive) beforeSave() {} // +checklocksignore func (k *keepalive) StateSave(stateSinkObject state.Sink) { k.beforeSave() stateSinkObject.Save(0, &k.idle) stateSinkObject.Save(1, &k.interval) stateSinkObject.Save(2, &k.count) stateSinkObject.Save(3, &k.unacked) } func (k *keepalive) afterLoad() {} // +checklocksignore func (k *keepalive) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &k.idle) stateSourceObject.Load(1, &k.interval) stateSourceObject.Load(2, &k.count) stateSourceObject.Load(3, &k.unacked) } func (rc *rackControl) StateTypeName() string { return "pkg/tcpip/transport/tcp.rackControl" } func (rc *rackControl) StateFields() []string { return []string{ "TCPRACKState", "exitedRecovery", "minRTT", "tlpRxtOut", "tlpHighRxt", "snd", } } func (rc *rackControl) beforeSave() {} // +checklocksignore func (rc *rackControl) StateSave(stateSinkObject state.Sink) { rc.beforeSave() stateSinkObject.Save(0, &rc.TCPRACKState) stateSinkObject.Save(1, &rc.exitedRecovery) stateSinkObject.Save(2, &rc.minRTT) stateSinkObject.Save(3, &rc.tlpRxtOut) stateSinkObject.Save(4, &rc.tlpHighRxt) stateSinkObject.Save(5, &rc.snd) } func (rc *rackControl) afterLoad() {} // +checklocksignore func (rc *rackControl) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &rc.TCPRACKState) stateSourceObject.Load(1, &rc.exitedRecovery) stateSourceObject.Load(2, &rc.minRTT) stateSourceObject.Load(3, &rc.tlpRxtOut) stateSourceObject.Load(4, &rc.tlpHighRxt) stateSourceObject.Load(5, &rc.snd) } func (r *receiver) StateTypeName() string { return "pkg/tcpip/transport/tcp.receiver" } func (r *receiver) StateFields() []string { return []string{ "TCPReceiverState", "ep", "rcvWnd", "rcvWUP", "prevBufUsed", "closed", "pendingRcvdSegments", "lastRcvdAckTime", } } func (r *receiver) beforeSave() {} // +checklocksignore func (r *receiver) StateSave(stateSinkObject state.Sink) { r.beforeSave() stateSinkObject.Save(0, &r.TCPReceiverState) stateSinkObject.Save(1, &r.ep) stateSinkObject.Save(2, &r.rcvWnd) stateSinkObject.Save(3, &r.rcvWUP) stateSinkObject.Save(4, &r.prevBufUsed) stateSinkObject.Save(5, &r.closed) stateSinkObject.Save(6, &r.pendingRcvdSegments) stateSinkObject.Save(7, &r.lastRcvdAckTime) } func (r *receiver) afterLoad() {} // +checklocksignore func (r *receiver) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &r.TCPReceiverState) stateSourceObject.Load(1, &r.ep) stateSourceObject.Load(2, &r.rcvWnd) stateSourceObject.Load(3, &r.rcvWUP) stateSourceObject.Load(4, &r.prevBufUsed) stateSourceObject.Load(5, &r.closed) stateSourceObject.Load(6, &r.pendingRcvdSegments) stateSourceObject.Load(7, &r.lastRcvdAckTime) } func (r *renoState) StateTypeName() string { return "pkg/tcpip/transport/tcp.renoState" } func (r *renoState) StateFields() []string { return []string{ "s", } } func (r *renoState) beforeSave() {} // +checklocksignore func (r *renoState) StateSave(stateSinkObject state.Sink) { r.beforeSave() stateSinkObject.Save(0, &r.s) } func (r *renoState) afterLoad() {} // +checklocksignore func (r *renoState) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &r.s) } func (rr *renoRecovery) StateTypeName() string { return "pkg/tcpip/transport/tcp.renoRecovery" } func (rr *renoRecovery) StateFields() []string { return []string{ "s", } } func (rr *renoRecovery) beforeSave() {} // +checklocksignore func (rr *renoRecovery) StateSave(stateSinkObject state.Sink) { rr.beforeSave() stateSinkObject.Save(0, &rr.s) } func (rr *renoRecovery) afterLoad() {} // +checklocksignore func (rr *renoRecovery) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &rr.s) } func (sr *sackRecovery) StateTypeName() string { return "pkg/tcpip/transport/tcp.sackRecovery" } func (sr *sackRecovery) StateFields() []string { return []string{ "s", } } func (sr *sackRecovery) beforeSave() {} // +checklocksignore func (sr *sackRecovery) StateSave(stateSinkObject state.Sink) { sr.beforeSave() stateSinkObject.Save(0, &sr.s) } func (sr *sackRecovery) afterLoad() {} // +checklocksignore func (sr *sackRecovery) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &sr.s) } func (s *SACKScoreboard) StateTypeName() string { return "pkg/tcpip/transport/tcp.SACKScoreboard" } func (s *SACKScoreboard) StateFields() []string { return []string{ "smss", "maxSACKED", } } func (s *SACKScoreboard) beforeSave() {} // +checklocksignore func (s *SACKScoreboard) StateSave(stateSinkObject state.Sink) { s.beforeSave() stateSinkObject.Save(0, &s.smss) stateSinkObject.Save(1, &s.maxSACKED) } func (s *SACKScoreboard) afterLoad() {} // +checklocksignore func (s *SACKScoreboard) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &s.smss) stateSourceObject.Load(1, &s.maxSACKED) } func (s *segment) StateTypeName() string { return "pkg/tcpip/transport/tcp.segment" } func (s *segment) StateFields() []string { return []string{ "segmentEntry", "refCnt", "ep", "qFlags", "srcAddr", "dstAddr", "netProto", "nicID", "data", "hdr", "sequenceNumber", "ackNumber", "flags", "window", "csum", "csumValid", "parsedOptions", "options", "hasNewSACKInfo", "rcvdTime", "xmitTime", "xmitCount", "acked", "dataMemSize", "lost", } } func (s *segment) beforeSave() {} // +checklocksignore func (s *segment) StateSave(stateSinkObject state.Sink) { s.beforeSave() var dataValue buffer.VectorisedView dataValue = s.saveData() stateSinkObject.SaveValue(8, dataValue) var optionsValue []byte optionsValue = s.saveOptions() stateSinkObject.SaveValue(17, optionsValue) stateSinkObject.Save(0, &s.segmentEntry) stateSinkObject.Save(1, &s.refCnt) stateSinkObject.Save(2, &s.ep) stateSinkObject.Save(3, &s.qFlags) stateSinkObject.Save(4, &s.srcAddr) stateSinkObject.Save(5, &s.dstAddr) stateSinkObject.Save(6, &s.netProto) stateSinkObject.Save(7, &s.nicID) stateSinkObject.Save(9, &s.hdr) stateSinkObject.Save(10, &s.sequenceNumber) stateSinkObject.Save(11, &s.ackNumber) stateSinkObject.Save(12, &s.flags) stateSinkObject.Save(13, &s.window) stateSinkObject.Save(14, &s.csum) stateSinkObject.Save(15, &s.csumValid) stateSinkObject.Save(16, &s.parsedOptions) stateSinkObject.Save(18, &s.hasNewSACKInfo) stateSinkObject.Save(19, &s.rcvdTime) stateSinkObject.Save(20, &s.xmitTime) stateSinkObject.Save(21, &s.xmitCount) stateSinkObject.Save(22, &s.acked) stateSinkObject.Save(23, &s.dataMemSize) stateSinkObject.Save(24, &s.lost) } func (s *segment) afterLoad() {} // +checklocksignore func (s *segment) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &s.segmentEntry) stateSourceObject.Load(1, &s.refCnt) stateSourceObject.Load(2, &s.ep) stateSourceObject.Load(3, &s.qFlags) stateSourceObject.Load(4, &s.srcAddr) stateSourceObject.Load(5, &s.dstAddr) stateSourceObject.Load(6, &s.netProto) stateSourceObject.Load(7, &s.nicID) stateSourceObject.Load(9, &s.hdr) stateSourceObject.Load(10, &s.sequenceNumber) stateSourceObject.Load(11, &s.ackNumber) stateSourceObject.Load(12, &s.flags) stateSourceObject.Load(13, &s.window) stateSourceObject.Load(14, &s.csum) stateSourceObject.Load(15, &s.csumValid) stateSourceObject.Load(16, &s.parsedOptions) stateSourceObject.Load(18, &s.hasNewSACKInfo) stateSourceObject.Load(19, &s.rcvdTime) stateSourceObject.Load(20, &s.xmitTime) stateSourceObject.Load(21, &s.xmitCount) stateSourceObject.Load(22, &s.acked) stateSourceObject.Load(23, &s.dataMemSize) stateSourceObject.Load(24, &s.lost) stateSourceObject.LoadValue(8, new(buffer.VectorisedView), func(y interface{}) { s.loadData(y.(buffer.VectorisedView)) }) stateSourceObject.LoadValue(17, new([]byte), func(y interface{}) { s.loadOptions(y.([]byte)) }) } func (q *segmentQueue) StateTypeName() string { return "pkg/tcpip/transport/tcp.segmentQueue" } func (q *segmentQueue) StateFields() []string { return []string{ "list", "ep", "frozen", } } func (q *segmentQueue) beforeSave() {} // +checklocksignore func (q *segmentQueue) StateSave(stateSinkObject state.Sink) { q.beforeSave() stateSinkObject.Save(0, &q.list) stateSinkObject.Save(1, &q.ep) stateSinkObject.Save(2, &q.frozen) } func (q *segmentQueue) afterLoad() {} // +checklocksignore func (q *segmentQueue) StateLoad(stateSourceObject state.Source) { stateSourceObject.LoadWait(0, &q.list) stateSourceObject.Load(1, &q.ep) stateSourceObject.Load(2, &q.frozen) } func (s *sender) StateTypeName() string { return "pkg/tcpip/transport/tcp.sender" } func (s *sender) StateFields() []string { return []string{ "TCPSenderState", "ep", "lr", "firstRetransmittedSegXmitTime", "writeNext", "writeList", "rtt", "minRTO", "maxRTO", "maxRetries", "gso", "state", "cc", "rc", "spuriousRecovery", "retransmitTS", } } func (s *sender) beforeSave() {} // +checklocksignore func (s *sender) StateSave(stateSinkObject state.Sink) { s.beforeSave() stateSinkObject.Save(0, &s.TCPSenderState) stateSinkObject.Save(1, &s.ep) stateSinkObject.Save(2, &s.lr) stateSinkObject.Save(3, &s.firstRetransmittedSegXmitTime) stateSinkObject.Save(4, &s.writeNext) stateSinkObject.Save(5, &s.writeList) stateSinkObject.Save(6, &s.rtt) stateSinkObject.Save(7, &s.minRTO) stateSinkObject.Save(8, &s.maxRTO) stateSinkObject.Save(9, &s.maxRetries) stateSinkObject.Save(10, &s.gso) stateSinkObject.Save(11, &s.state) stateSinkObject.Save(12, &s.cc) stateSinkObject.Save(13, &s.rc) stateSinkObject.Save(14, &s.spuriousRecovery) stateSinkObject.Save(15, &s.retransmitTS) } func (s *sender) afterLoad() {} // +checklocksignore func (s *sender) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &s.TCPSenderState) stateSourceObject.Load(1, &s.ep) stateSourceObject.Load(2, &s.lr) stateSourceObject.Load(3, &s.firstRetransmittedSegXmitTime) stateSourceObject.Load(4, &s.writeNext) stateSourceObject.Load(5, &s.writeList) stateSourceObject.Load(6, &s.rtt) stateSourceObject.Load(7, &s.minRTO) stateSourceObject.Load(8, &s.maxRTO) stateSourceObject.Load(9, &s.maxRetries) stateSourceObject.Load(10, &s.gso) stateSourceObject.Load(11, &s.state) stateSourceObject.Load(12, &s.cc) stateSourceObject.Load(13, &s.rc) stateSourceObject.Load(14, &s.spuriousRecovery) stateSourceObject.Load(15, &s.retransmitTS) } func (r *rtt) StateTypeName() string { return "pkg/tcpip/transport/tcp.rtt" } func (r *rtt) StateFields() []string { return []string{ "TCPRTTState", } } func (r *rtt) beforeSave() {} // +checklocksignore func (r *rtt) StateSave(stateSinkObject state.Sink) { r.beforeSave() stateSinkObject.Save(0, &r.TCPRTTState) } func (r *rtt) afterLoad() {} // +checklocksignore func (r *rtt) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &r.TCPRTTState) } func (l *endpointList) StateTypeName() string { return "pkg/tcpip/transport/tcp.endpointList" } func (l *endpointList) StateFields() []string { return []string{ "head", "tail", } } func (l *endpointList) beforeSave() {} // +checklocksignore func (l *endpointList) StateSave(stateSinkObject state.Sink) { l.beforeSave() stateSinkObject.Save(0, &l.head) stateSinkObject.Save(1, &l.tail) } func (l *endpointList) afterLoad() {} // +checklocksignore func (l *endpointList) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &l.head) stateSourceObject.Load(1, &l.tail) } func (e *endpointEntry) StateTypeName() string { return "pkg/tcpip/transport/tcp.endpointEntry" } func (e *endpointEntry) StateFields() []string { return []string{ "next", "prev", } } func (e *endpointEntry) beforeSave() {} // +checklocksignore func (e *endpointEntry) StateSave(stateSinkObject state.Sink) { e.beforeSave() stateSinkObject.Save(0, &e.next) stateSinkObject.Save(1, &e.prev) } func (e *endpointEntry) afterLoad() {} // +checklocksignore func (e *endpointEntry) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &e.next) stateSourceObject.Load(1, &e.prev) } func (l *segmentList) StateTypeName() string { return "pkg/tcpip/transport/tcp.segmentList" } func (l *segmentList) StateFields() []string { return []string{ "head", "tail", } } func (l *segmentList) beforeSave() {} // +checklocksignore func (l *segmentList) StateSave(stateSinkObject state.Sink) { l.beforeSave() stateSinkObject.Save(0, &l.head) stateSinkObject.Save(1, &l.tail) } func (l *segmentList) afterLoad() {} // +checklocksignore func (l *segmentList) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &l.head) stateSourceObject.Load(1, &l.tail) } func (e *segmentEntry) StateTypeName() string { return "pkg/tcpip/transport/tcp.segmentEntry" } func (e *segmentEntry) StateFields() []string { return []string{ "next", "prev", } } func (e *segmentEntry) beforeSave() {} // +checklocksignore func (e *segmentEntry) StateSave(stateSinkObject state.Sink) { e.beforeSave() stateSinkObject.Save(0, &e.next) stateSinkObject.Save(1, &e.prev) } func (e *segmentEntry) afterLoad() {} // +checklocksignore func (e *segmentEntry) StateLoad(stateSourceObject state.Source) { stateSourceObject.Load(0, &e.next) stateSourceObject.Load(1, &e.prev) } func init() { state.Register((*acceptQueue)(nil)) state.Register((*cubicState)(nil)) state.Register((*SACKInfo)(nil)) state.Register((*ReceiveErrors)(nil)) state.Register((*SendErrors)(nil)) state.Register((*Stats)(nil)) state.Register((*sndQueueInfo)(nil)) state.Register((*rcvQueueInfo)(nil)) state.Register((*endpoint)(nil)) state.Register((*keepalive)(nil)) state.Register((*rackControl)(nil)) state.Register((*receiver)(nil)) state.Register((*renoState)(nil)) state.Register((*renoRecovery)(nil)) state.Register((*sackRecovery)(nil)) state.Register((*SACKScoreboard)(nil)) state.Register((*segment)(nil)) state.Register((*segmentQueue)(nil)) state.Register((*sender)(nil)) state.Register((*rtt)(nil)) state.Register((*endpointList)(nil)) state.Register((*endpointEntry)(nil)) state.Register((*segmentList)(nil)) state.Register((*segmentEntry)(nil)) }