--- /dev/null
+// compile
+
+// Copyright 2019 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+// This code failed on arm64 in the register allocator.
+// See issue 33355.
+
+package server
+
+import (
+       "bytes"
+       "sync"
+)
+
+type client struct {
+       junk [4]int
+       mu   sync.Mutex
+       srv  *Server
+       gw   *gateway
+       msgb [100]byte
+}
+
+type gateway struct {
+       cfg    *gatewayCfg
+       outsim *sync.Map
+}
+
+type gatewayCfg struct {
+       replyPfx []byte
+}
+
+type Account struct {
+       Name string
+}
+
+type Server struct {
+       gateway *srvGateway
+}
+
+type srvGateway struct {
+       outo     []*client
+}
+
+type subscription struct {
+       queue   []byte
+       client  *client
+}
+
+type outsie struct {
+       ni    map[string]struct{}
+       sl    *Sublist
+       qsubs int
+}
+
+type Sublist struct {
+}
+
+type SublistResult struct {
+       psubs []*subscription
+       qsubs [][]*subscription
+}
+
+var subPool = &sync.Pool{}
+
+func (c *client) sendMsgToGateways(acc *Account, msg, subject, reply []byte, qgroups [][]byte) {
+       var gws []*client
+       gw := c.srv.gateway
+       for i := 0; i < len(gw.outo); i++ {
+               gws = append(gws, gw.outo[i])
+       }
+       var (
+               subj       = string(subject)
+               queuesa    = [512]byte{}
+               queues     = queuesa[:0]
+               mreply     []byte
+               dstPfx     []byte
+               checkReply = len(reply) > 0
+       )
+
+       sub := subPool.Get().(*subscription)
+
+       if subjectStartsWithGatewayReplyPrefix(subject) {
+               dstPfx = subject[:8]
+       }
+       for i := 0; i < len(gws); i++ {
+               gwc := gws[i]
+               if dstPfx != nil {
+                       gwc.mu.Lock()
+                       ok := bytes.Equal(dstPfx, gwc.gw.cfg.replyPfx)
+                       gwc.mu.Unlock()
+                       if !ok {
+                               continue
+                       }
+               } else {
+                       qr := gwc.gatewayInterest(acc.Name, subj)
+                       queues = queuesa[:0]
+                       for i := 0; i < len(qr.qsubs); i++ {
+                               qsubs := qr.qsubs[i]
+                               queue := qsubs[0].queue
+                               add := true
+                               for _, qn := range qgroups {
+                                       if bytes.Equal(queue, qn) {
+                                               add = false
+                                               break
+                                       }
+                               }
+                               if add {
+                                       qgroups = append(qgroups, queue)
+                               }
+                       }
+                       if len(queues) == 0 {
+                               continue
+                       }
+               }
+               if checkReply {
+                       checkReply = false
+                       mreply = reply
+               }
+               mh := c.msgb[:10]
+               mh = append(mh, subject...)
+               if len(queues) > 0 {
+                       mh = append(mh, mreply...)
+                       mh = append(mh, queues...)
+               }
+               sub.client = gwc
+       }
+       subPool.Put(sub)
+}
+
+func subjectStartsWithGatewayReplyPrefix(subj []byte) bool {
+       return len(subj) > 8 && string(subj[:4]) == "foob"
+}
+
+func (c *client) gatewayInterest(acc, subj string) *SublistResult {
+       ei, _ := c.gw.outsim.Load(acc)
+       var r *SublistResult
+       e := ei.(*outsie)
+       r = e.sl.Match(subj)
+       return r
+}
+
+func (s *Sublist) Match(subject string) *SublistResult {
+       return nil
+}
+