Commit a35297b6 authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 21902468
...@@ -67,6 +67,9 @@ type Conn struct { ...@@ -67,6 +67,9 @@ type Conn struct {
connId uint32 connId uint32
rxq chan *PktBuf // received packets for this Conn go here rxq chan *PktBuf // received packets for this Conn go here
txerr chan error // transmit errors for this Conn go back here txerr chan error // transmit errors for this Conn go back here
// Conn has to be explicitly closed by user; it can also be closed by NodeLink.Close
closeOnce sync.Once
closed chan struct{} closed chan struct{}
} }
...@@ -142,8 +145,7 @@ func (nl *NodeLink) Close() error { ...@@ -142,8 +145,7 @@ func (nl *NodeLink) Close() error {
// XXX only interrupt, not close? Or allow multiple conn.Close() ? // XXX only interrupt, not close? Or allow multiple conn.Close() ?
conn.close() // XXX err -> errv conn.close() // XXX err -> errv
} }
nl.connTab = nil // XXX ok? vs panic on NewConn after close ? nl.connTab = nil // clear + mark closed
return err return err
} }
...@@ -219,6 +221,9 @@ func (nl *NodeLink) newConn(connId uint32) *Conn { ...@@ -219,6 +221,9 @@ func (nl *NodeLink) newConn(connId uint32) *Conn {
func (nl *NodeLink) NewConn() *Conn { func (nl *NodeLink) NewConn() *Conn {
nl.connMu.Lock() nl.connMu.Lock()
defer nl.connMu.Unlock() defer nl.connMu.Unlock()
if nl.connTab == nil {
panic("NewConn() on closed node-link")
}
c := nl.newConn(nl.nextConnId) c := nl.newConn(nl.nextConnId)
nl.nextConnId += 2 nl.nextConnId += 2
return c return c
...@@ -340,7 +345,9 @@ func (c *Conn) Recv() (*PktBuf, error) { ...@@ -340,7 +345,9 @@ func (c *Conn) Recv() (*PktBuf, error) {
// worker for Close() & co // worker for Close() & co
func (c *Conn) close() { func (c *Conn) close() {
close(c.closed) // XXX better just close c.rxq + ??? for tx c.closeOnce.Do(func() {
close(c.closed) // XXX better just close c.rxq + ??? for tx
})
} }
// Close connection // Close connection
......
...@@ -138,7 +138,6 @@ func nodeLinkPipe() (nl1, nl2 *NodeLink) { ...@@ -138,7 +138,6 @@ func nodeLinkPipe() (nl1, nl2 *NodeLink) {
func TestNodeLink(t *testing.T) { func TestNodeLink(t *testing.T) {
// TODO catch exception -> add proper location from it -> t.Fatal (see git-backup) // TODO catch exception -> add proper location from it -> t.Fatal (see git-backup)
println("111")
nl1, nl2 := nodeLinkPipe() nl1, nl2 := nodeLinkPipe()
// Close vs recvPkt // Close vs recvPkt
...@@ -198,7 +197,6 @@ func TestNodeLink(t *testing.T) { ...@@ -198,7 +197,6 @@ func TestNodeLink(t *testing.T) {
// test channels on top of nodelink // test channels on top of nodelink
println("222")
nl1, nl2 = nodeLinkPipe() nl1, nl2 = nodeLinkPipe()
// Close vs Recv // Close vs Recv
...@@ -229,7 +227,6 @@ func TestNodeLink(t *testing.T) { ...@@ -229,7 +227,6 @@ func TestNodeLink(t *testing.T) {
xwait(wg) xwait(wg)
// NodeLink.Close vs Conn.Send/Recv // NodeLink.Close vs Conn.Send/Recv
println("333")
c11 := nl1.NewConn() c11 := nl1.NewConn()
c12 := nl1.NewConn() c12 := nl1.NewConn()
wg = WorkGroup() wg = WorkGroup()
...@@ -249,9 +246,10 @@ func TestNodeLink(t *testing.T) { ...@@ -249,9 +246,10 @@ func TestNodeLink(t *testing.T) {
tdelay() tdelay()
xclose(nl1) xclose(nl1)
xwait(wg) xwait(wg)
xclose(c11)
xclose(c12)
xclose(nl2) // for completeness xclose(nl2) // for completeness
println("444")
/* /*
......
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