Stream: git-wasmtime

Topic: wasmtime / issue #7244 Epoch performance issues


view this post on Zulip Wasmtime GitHub notifications bot (Oct 15 2023 at 14:51):

wjr-z opened issue #7244:

At present, there seem to be serious issues with the epoch mechanism and register usage。
For example, the following is a simple comparison of native and epoch assemblies for a double loop

wasmtiem release-13.0.0

native :

       0:   55                      push   %rbp
       1:   48 89 e5                mov    %rsp,%rbp
       4:   4c 8b 57 08             mov    0x8(%rdi),%r10
       8:   4d 8b 12                mov    (%r10),%r10
       b:   49 39 e2                cmp    %rsp,%r10
       e:   0f 87 2a 00 00 00       ja     3e <wasm[0]::function[0]+0x3e>
      14:   31 c9                   xor    %ecx,%ecx
      16:   45 31 c9                xor    %r9d,%r9d
      19:   41 83 c1 01             add    $0x1,%r9d
      1d:   41 81 f9 00 12 7a 00    cmp    $0x7a1200,%r9d
      24:   0f 8c ef ff ff ff       jl     19 <wasm[0]::function[0]+0x19>
      2a:   83 c1 01                add    $0x1,%ecx
      2d:   81 f9 40 9c 00 00       cmp    $0x9c40,%ecx
      33:   0f 8c dd ff ff ff       jl     16 <wasm[0]::function[0]+0x16>
      39:   48 89 ec                mov    %rbp,%rsp
      3c:   5d                      pop    %rbp
      3d:   c3                      retq
      3e:   0f 0b                   ud2

epoch :

       0:   55                      push   %rbp
       1:   48 89 e5                mov    %rsp,%rbp
       4:   4c 8b 57 08             mov    0x8(%rdi),%r10
       8:   4d 8b 12                mov    (%r10),%r10
       b:   49 39 e2                cmp    %rsp,%r10
       e:   0f 87 04 01 00 00       ja     118 <wasm[0]::function[0]+0x118>
      14:   48 83 ec 20             sub    $0x20,%rsp
      18:   48 89 1c 24             mov    %rbx,(%rsp)
      1c:   4c 89 6c 24 08          mov    %r13,0x8(%rsp)
      21:   4c 89 7c 24 10          mov    %r15,0x10(%rsp)
      26:   48 8b 77 08             mov    0x8(%rdi),%rsi
      2a:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      2e:   4c 8b 6f 18             mov    0x18(%rdi),%r13
      32:   4d 8b 55 00             mov    0x0(%r13),%r10
      36:   4d 39 ca                cmp    %r9,%r10
      39:   0f 83 56 00 00 00       jae    95 <wasm[0]::function[0]+0x95>
      3f:   45 31 ff                xor    %r15d,%r15d
      42:   4d 8b 55 00             mov    0x0(%r13),%r10
      46:   4d 39 ca                cmp    %r9,%r10
      49:   0f 83 6f 00 00 00       jae    be <wasm[0]::function[0]+0xbe>
      4f:   31 db                   xor    %ebx,%ebx
      51:   4d 8b 5d 00             mov    0x0(%r13),%r11
      55:   4d 39 cb                cmp    %r9,%r11
      58:   0f 83 8d 00 00 00       jae    eb <wasm[0]::function[0]+0xeb>
      5e:   83 c3 01                add    $0x1,%ebx
      61:   81 fb 00 12 7a 00       cmp    $0x7a1200,%ebx
      67:   0f 8c e4 ff ff ff       jl     51 <wasm[0]::function[0]+0x51>
      6d:   41 83 c7 01             add    $0x1,%r15d
      71:   41 81 ff 40 9c 00 00    cmp    $0x9c40,%r15d
      78:   0f 8c c4 ff ff ff       jl     42 <wasm[0]::function[0]+0x42>
      7e:   48 8b 1c 24             mov    (%rsp),%rbx
      82:   4c 8b 6c 24 08          mov    0x8(%rsp),%r13
      87:   4c 8b 7c 24 10          mov    0x10(%rsp),%r15
      8c:   48 83 c4 20             add    $0x20,%rsp
      90:   48 89 ec                mov    %rbp,%rsp
      93:   5d                      pop    %rbp
      94:   c3                      retq
      95:   4d 39 ca                cmp    %r9,%r10
      98:   0f 82 a1 ff ff ff       jb     3f <wasm[0]::function[0]+0x3f>
      9e:   48 8b 47 38             mov    0x38(%rdi),%rax
      a2:   48 8b 80 b0 00 00 00    mov    0xb0(%rax),%rax
      a9:   48 83 ec 20             sub    $0x20,%rsp
      ad:   48 89 f9                mov    %rdi,%rcx
      b0:   ff d0                   callq  *%rax
      b2:   48 83 c4 20             add    $0x20,%rsp
      b6:   49 89 c1                mov    %rax,%r9
      b9:   e9 81 ff ff ff          jmpq   3f <wasm[0]::function[0]+0x3f>
      be:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      c2:   4d 39 ca                cmp    %r9,%r10
      c5:   0f 82 84 ff ff ff       jb     4f <wasm[0]::function[0]+0x4f>
      cb:   48 8b 47 38             mov    0x38(%rdi),%rax
      cf:   48 8b 80 b0 00 00 00    mov    0xb0(%rax),%rax
      d6:   48 83 ec 20             sub    $0x20,%rsp
      da:   48 89 f9                mov    %rdi,%rcx
      dd:   ff d0                   callq  *%rax
      df:   48 83 c4 20             add    $0x20,%rsp
      e3:   49 89 c1                mov    %rax,%r9
      e6:   e9 64 ff ff ff          jmpq   4f <wasm[0]::function[0]+0x4f>
      eb:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      ef:   4d 39 cb                cmp    %r9,%r11
      f2:   0f 82 66 ff ff ff       jb     5e <wasm[0]::function[0]+0x5e>
      f8:   48 8b 4f 38             mov    0x38(%rdi),%rcx
      fc:   48 8b 91 b0 00 00 00    mov    0xb0(%rcx),%rdx
     103:   48 83 ec 20             sub    $0x20,%rsp
     107:   48 89 f9                mov    %rdi,%rcx
     10a:   ff d2                   callq  *%rdx
     10c:   48 83 c4 20             add    $0x20,%rsp
     110:   49 89 c1                mov    %rax,%r9
     113:   e9 46 ff ff ff          jmpq   5e <wasm[0]::function[0]+0x5e>
     118:   0f 0b                   ud2

The above example assigns some registers, such as ax and cx, to the check block of epoch. And bx has not been allocated for use at all. Actually, this is just a simple example, and more complex workloads have a significant performance impact on the box_seal.wasm, the cost has reached 25%! And after trying to manually fix the issue with epoch (non portable), the cost was only less than 7%.

view this post on Zulip Wasmtime GitHub notifications bot (Oct 15 2023 at 14:54):

wjr-z edited issue #7244:

At present, there seem to be serious issues with the epoch mechanism and register usage。
For example, the following is a simple comparison of native and epoch assemblies for a double loop

wasmtiem release-13.0.0

native :

       0:   55                      push   %rbp
       1:   48 89 e5                mov    %rsp,%rbp
       4:   4c 8b 57 08             mov    0x8(%rdi),%r10
       8:   4d 8b 12                mov    (%r10),%r10
       b:   49 39 e2                cmp    %rsp,%r10
       e:   0f 87 2a 00 00 00       ja     3e <wasm[0]::function[0]+0x3e>
      14:   31 c9                   xor    %ecx,%ecx
      16:   45 31 c9                xor    %r9d,%r9d
      19:   41 83 c1 01             add    $0x1,%r9d
      1d:   41 81 f9 00 12 7a 00    cmp    $0x7a1200,%r9d
      24:   0f 8c ef ff ff ff       jl     19 <wasm[0]::function[0]+0x19>
      2a:   83 c1 01                add    $0x1,%ecx
      2d:   81 f9 40 9c 00 00       cmp    $0x9c40,%ecx
      33:   0f 8c dd ff ff ff       jl     16 <wasm[0]::function[0]+0x16>
      39:   48 89 ec                mov    %rbp,%rsp
      3c:   5d                      pop    %rbp
      3d:   c3                      retq
      3e:   0f 0b                   ud2

epoch :

       0:   55                      push   %rbp
       1:   48 89 e5                mov    %rsp,%rbp
       4:   4c 8b 57 08             mov    0x8(%rdi),%r10
       8:   4d 8b 12                mov    (%r10),%r10
       b:   49 39 e2                cmp    %rsp,%r10
       e:   0f 87 04 01 00 00       ja     118 <wasm[0]::function[0]+0x118>
      14:   48 83 ec 20             sub    $0x20,%rsp
      18:   48 89 1c 24             mov    %rbx,(%rsp)
      1c:   4c 89 6c 24 08          mov    %r13,0x8(%rsp)
      21:   4c 89 7c 24 10          mov    %r15,0x10(%rsp)
      26:   48 8b 77 08             mov    0x8(%rdi),%rsi
      2a:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      2e:   4c 8b 6f 18             mov    0x18(%rdi),%r13
      32:   4d 8b 55 00             mov    0x0(%r13),%r10
      36:   4d 39 ca                cmp    %r9,%r10
      39:   0f 83 56 00 00 00       jae    95 <wasm[0]::function[0]+0x95>
      3f:   45 31 ff                xor    %r15d,%r15d
      42:   4d 8b 55 00             mov    0x0(%r13),%r10
      46:   4d 39 ca                cmp    %r9,%r10
      49:   0f 83 6f 00 00 00       jae    be <wasm[0]::function[0]+0xbe>
      4f:   31 db                   xor    %ebx,%ebx
      51:   4d 8b 5d 00             mov    0x0(%r13),%r11
      55:   4d 39 cb                cmp    %r9,%r11
      58:   0f 83 8d 00 00 00       jae    eb <wasm[0]::function[0]+0xeb>
      5e:   83 c3 01                add    $0x1,%ebx
      61:   81 fb 00 12 7a 00       cmp    $0x7a1200,%ebx
      67:   0f 8c e4 ff ff ff       jl     51 <wasm[0]::function[0]+0x51>
      6d:   41 83 c7 01             add    $0x1,%r15d
      71:   41 81 ff 40 9c 00 00    cmp    $0x9c40,%r15d
      78:   0f 8c c4 ff ff ff       jl     42 <wasm[0]::function[0]+0x42>
      7e:   48 8b 1c 24             mov    (%rsp),%rbx
      82:   4c 8b 6c 24 08          mov    0x8(%rsp),%r13
      87:   4c 8b 7c 24 10          mov    0x10(%rsp),%r15
      8c:   48 83 c4 20             add    $0x20,%rsp
      90:   48 89 ec                mov    %rbp,%rsp
      93:   5d                      pop    %rbp
      94:   c3                      retq
      95:   4d 39 ca                cmp    %r9,%r10
      98:   0f 82 a1 ff ff ff       jb     3f <wasm[0]::function[0]+0x3f>
      9e:   48 8b 47 38             mov    0x38(%rdi),%rax
      a2:   48 8b 80 b0 00 00 00    mov    0xb0(%rax),%rax
      a9:   48 83 ec 20             sub    $0x20,%rsp
      ad:   48 89 f9                mov    %rdi,%rcx
      b0:   ff d0                   callq  *%rax
      b2:   48 83 c4 20             add    $0x20,%rsp
      b6:   49 89 c1                mov    %rax,%r9
      b9:   e9 81 ff ff ff          jmpq   3f <wasm[0]::function[0]+0x3f>
      be:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      c2:   4d 39 ca                cmp    %r9,%r10
      c5:   0f 82 84 ff ff ff       jb     4f <wasm[0]::function[0]+0x4f>
      cb:   48 8b 47 38             mov    0x38(%rdi),%rax
      cf:   48 8b 80 b0 00 00 00    mov    0xb0(%rax),%rax
      d6:   48 83 ec 20             sub    $0x20,%rsp
      da:   48 89 f9                mov    %rdi,%rcx
      dd:   ff d0                   callq  *%rax
      df:   48 83 c4 20             add    $0x20,%rsp
      e3:   49 89 c1                mov    %rax,%r9
      e6:   e9 64 ff ff ff          jmpq   4f <wasm[0]::function[0]+0x4f>
      eb:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      ef:   4d 39 cb                cmp    %r9,%r11
      f2:   0f 82 66 ff ff ff       jb     5e <wasm[0]::function[0]+0x5e>
      f8:   48 8b 4f 38             mov    0x38(%rdi),%rcx
      fc:   48 8b 91 b0 00 00 00    mov    0xb0(%rcx),%rdx
     103:   48 83 ec 20             sub    $0x20,%rsp
     107:   48 89 f9                mov    %rdi,%rcx
     10a:   ff d2                   callq  *%rdx
     10c:   48 83 c4 20             add    $0x20,%rsp
     110:   49 89 c1                mov    %rax,%r9
     113:   e9 46 ff ff ff          jmpq   5e <wasm[0]::function[0]+0x5e>
     118:   0f 0b                   ud2

The above example assigns some registers, such as ax and cx, to the check block of epoch. Actually, this is just a simple example, and more complex workloads have a significant performance impact on the box_seal.wasm, the cost has reached 25%! And after trying to manually fix the issue with epoch (non portable), the cost was only less than 7%.

view this post on Zulip Wasmtime GitHub notifications bot (Oct 15 2023 at 14:54):

wjr-z edited issue #7244:

At present, there seem to be serious issues with the epoch mechanism and register usage。
For example, the following is a simple comparison of native and epoch assemblies for a double loop

wasmtiem release-13.0.0

native :

       0:   55                      push   %rbp
       1:   48 89 e5                mov    %rsp,%rbp
       4:   4c 8b 57 08             mov    0x8(%rdi),%r10
       8:   4d 8b 12                mov    (%r10),%r10
       b:   49 39 e2                cmp    %rsp,%r10
       e:   0f 87 2a 00 00 00       ja     3e <wasm[0]::function[0]+0x3e>
      14:   31 c9                   xor    %ecx,%ecx
      16:   45 31 c9                xor    %r9d,%r9d
      19:   41 83 c1 01             add    $0x1,%r9d
      1d:   41 81 f9 00 12 7a 00    cmp    $0x7a1200,%r9d
      24:   0f 8c ef ff ff ff       jl     19 <wasm[0]::function[0]+0x19>
      2a:   83 c1 01                add    $0x1,%ecx
      2d:   81 f9 40 9c 00 00       cmp    $0x9c40,%ecx
      33:   0f 8c dd ff ff ff       jl     16 <wasm[0]::function[0]+0x16>
      39:   48 89 ec                mov    %rbp,%rsp
      3c:   5d                      pop    %rbp
      3d:   c3                      retq
      3e:   0f 0b                   ud2

epoch :

       0:   55                      push   %rbp
       1:   48 89 e5                mov    %rsp,%rbp
       4:   4c 8b 57 08             mov    0x8(%rdi),%r10
       8:   4d 8b 12                mov    (%r10),%r10
       b:   49 39 e2                cmp    %rsp,%r10
       e:   0f 87 04 01 00 00       ja     118 <wasm[0]::function[0]+0x118>
      14:   48 83 ec 20             sub    $0x20,%rsp
      18:   48 89 1c 24             mov    %rbx,(%rsp)
      1c:   4c 89 6c 24 08          mov    %r13,0x8(%rsp)
      21:   4c 89 7c 24 10          mov    %r15,0x10(%rsp)
      26:   48 8b 77 08             mov    0x8(%rdi),%rsi
      2a:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      2e:   4c 8b 6f 18             mov    0x18(%rdi),%r13
      32:   4d 8b 55 00             mov    0x0(%r13),%r10
      36:   4d 39 ca                cmp    %r9,%r10
      39:   0f 83 56 00 00 00       jae    95 <wasm[0]::function[0]+0x95>
      3f:   45 31 ff                xor    %r15d,%r15d
      42:   4d 8b 55 00             mov    0x0(%r13),%r10
      46:   4d 39 ca                cmp    %r9,%r10
      49:   0f 83 6f 00 00 00       jae    be <wasm[0]::function[0]+0xbe>
      4f:   31 db                   xor    %ebx,%ebx
      51:   4d 8b 5d 00             mov    0x0(%r13),%r11
      55:   4d 39 cb                cmp    %r9,%r11
      58:   0f 83 8d 00 00 00       jae    eb <wasm[0]::function[0]+0xeb>
      5e:   83 c3 01                add    $0x1,%ebx
      61:   81 fb 00 12 7a 00       cmp    $0x7a1200,%ebx
      67:   0f 8c e4 ff ff ff       jl     51 <wasm[0]::function[0]+0x51>
      6d:   41 83 c7 01             add    $0x1,%r15d
      71:   41 81 ff 40 9c 00 00    cmp    $0x9c40,%r15d
      78:   0f 8c c4 ff ff ff       jl     42 <wasm[0]::function[0]+0x42>
      7e:   48 8b 1c 24             mov    (%rsp),%rbx
      82:   4c 8b 6c 24 08          mov    0x8(%rsp),%r13
      87:   4c 8b 7c 24 10          mov    0x10(%rsp),%r15
      8c:   48 83 c4 20             add    $0x20,%rsp
      90:   48 89 ec                mov    %rbp,%rsp
      93:   5d                      pop    %rbp
      94:   c3                      retq
      95:   4d 39 ca                cmp    %r9,%r10
      98:   0f 82 a1 ff ff ff       jb     3f <wasm[0]::function[0]+0x3f>
      9e:   48 8b 47 38             mov    0x38(%rdi),%rax
      a2:   48 8b 80 b0 00 00 00    mov    0xb0(%rax),%rax
      a9:   48 83 ec 20             sub    $0x20,%rsp
      ad:   48 89 f9                mov    %rdi,%rcx
      b0:   ff d0                   callq  *%rax
      b2:   48 83 c4 20             add    $0x20,%rsp
      b6:   49 89 c1                mov    %rax,%r9
      b9:   e9 81 ff ff ff          jmpq   3f <wasm[0]::function[0]+0x3f>
      be:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      c2:   4d 39 ca                cmp    %r9,%r10
      c5:   0f 82 84 ff ff ff       jb     4f <wasm[0]::function[0]+0x4f>
      cb:   48 8b 47 38             mov    0x38(%rdi),%rax
      cf:   48 8b 80 b0 00 00 00    mov    0xb0(%rax),%rax
      d6:   48 83 ec 20             sub    $0x20,%rsp
      da:   48 89 f9                mov    %rdi,%rcx
      dd:   ff d0                   callq  *%rax
      df:   48 83 c4 20             add    $0x20,%rsp
      e3:   49 89 c1                mov    %rax,%r9
      e6:   e9 64 ff ff ff          jmpq   4f <wasm[0]::function[0]+0x4f>
      eb:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      ef:   4d 39 cb                cmp    %r9,%r11
      f2:   0f 82 66 ff ff ff       jb     5e <wasm[0]::function[0]+0x5e>
      f8:   48 8b 4f 38             mov    0x38(%rdi),%rcx
      fc:   48 8b 91 b0 00 00 00    mov    0xb0(%rcx),%rdx
     103:   48 83 ec 20             sub    $0x20,%rsp
     107:   48 89 f9                mov    %rdi,%rcx
     10a:   ff d2                   callq  *%rdx
     10c:   48 83 c4 20             add    $0x20,%rsp
     110:   49 89 c1                mov    %rax,%r9
     113:   e9 46 ff ff ff          jmpq   5e <wasm[0]::function[0]+0x5e>
     118:   0f 0b                   ud2

The above example assigns some registers, such as ax and cx, to the check block of epoch. Actually, this is just a simple example, and more complex workloads have a significant performance impact on the box_seal.wasm, the cost has reached 25%! And after trying to manually fix the issue with epoch (Unstable), the cost was only less than 7%.

view this post on Zulip Wasmtime GitHub notifications bot (Oct 15 2023 at 15:20):

wjr-z edited issue #7244:

At present, there seem to be serious issues with the epoch mechanism and register usage。
For example, the following is a simple comparison of native and epoch assemblies for a double loop

wasmtiem release-13.0.0

native :

       0:   55                      push   %rbp
       1:   48 89 e5                mov    %rsp,%rbp
       4:   4c 8b 57 08             mov    0x8(%rdi),%r10
       8:   4d 8b 12                mov    (%r10),%r10
       b:   49 39 e2                cmp    %rsp,%r10
       e:   0f 87 2a 00 00 00       ja     3e <wasm[0]::function[0]+0x3e>
      14:   31 c9                   xor    %ecx,%ecx
      16:   45 31 c9                xor    %r9d,%r9d
      19:   41 83 c1 01             add    $0x1,%r9d
      1d:   41 81 f9 00 12 7a 00    cmp    $0x7a1200,%r9d
      24:   0f 8c ef ff ff ff       jl     19 <wasm[0]::function[0]+0x19>
      2a:   83 c1 01                add    $0x1,%ecx
      2d:   81 f9 40 9c 00 00       cmp    $0x9c40,%ecx
      33:   0f 8c dd ff ff ff       jl     16 <wasm[0]::function[0]+0x16>
      39:   48 89 ec                mov    %rbp,%rsp
      3c:   5d                      pop    %rbp
      3d:   c3                      retq
      3e:   0f 0b                   ud2

epoch :

       0:   55                      push   %rbp
       1:   48 89 e5                mov    %rsp,%rbp
       4:   4c 8b 57 08             mov    0x8(%rdi),%r10
       8:   4d 8b 12                mov    (%r10),%r10
       b:   49 39 e2                cmp    %rsp,%r10
       e:   0f 87 04 01 00 00       ja     118 <wasm[0]::function[0]+0x118>
      14:   48 83 ec 20             sub    $0x20,%rsp
      18:   48 89 1c 24             mov    %rbx,(%rsp)
      1c:   4c 89 6c 24 08          mov    %r13,0x8(%rsp)
      21:   4c 89 7c 24 10          mov    %r15,0x10(%rsp)
      26:   48 8b 77 08             mov    0x8(%rdi),%rsi
      2a:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      2e:   4c 8b 6f 18             mov    0x18(%rdi),%r13
      32:   4d 8b 55 00             mov    0x0(%r13),%r10
      36:   4d 39 ca                cmp    %r9,%r10
      39:   0f 83 56 00 00 00       jae    95 <wasm[0]::function[0]+0x95>
      3f:   45 31 ff                xor    %r15d,%r15d
      42:   4d 8b 55 00             mov    0x0(%r13),%r10
      46:   4d 39 ca                cmp    %r9,%r10
      49:   0f 83 6f 00 00 00       jae    be <wasm[0]::function[0]+0xbe>
      4f:   31 db                   xor    %ebx,%ebx
      51:   4d 8b 5d 00             mov    0x0(%r13),%r11
      55:   4d 39 cb                cmp    %r9,%r11
      58:   0f 83 8d 00 00 00       jae    eb <wasm[0]::function[0]+0xeb>
      5e:   83 c3 01                add    $0x1,%ebx
      61:   81 fb 00 12 7a 00       cmp    $0x7a1200,%ebx
      67:   0f 8c e4 ff ff ff       jl     51 <wasm[0]::function[0]+0x51>
      6d:   41 83 c7 01             add    $0x1,%r15d
      71:   41 81 ff 40 9c 00 00    cmp    $0x9c40,%r15d
      78:   0f 8c c4 ff ff ff       jl     42 <wasm[0]::function[0]+0x42>
      7e:   48 8b 1c 24             mov    (%rsp),%rbx
      82:   4c 8b 6c 24 08          mov    0x8(%rsp),%r13
      87:   4c 8b 7c 24 10          mov    0x10(%rsp),%r15
      8c:   48 83 c4 20             add    $0x20,%rsp
      90:   48 89 ec                mov    %rbp,%rsp
      93:   5d                      pop    %rbp
      94:   c3                      retq
      95:   4d 39 ca                cmp    %r9,%r10
      98:   0f 82 a1 ff ff ff       jb     3f <wasm[0]::function[0]+0x3f>
      9e:   48 8b 47 38             mov    0x38(%rdi),%rax
      a2:   48 8b 80 b0 00 00 00    mov    0xb0(%rax),%rax
      a9:   48 83 ec 20             sub    $0x20,%rsp
      ad:   48 89 f9                mov    %rdi,%rcx
      b0:   ff d0                   callq  *%rax
      b2:   48 83 c4 20             add    $0x20,%rsp
      b6:   49 89 c1                mov    %rax,%r9
      b9:   e9 81 ff ff ff          jmpq   3f <wasm[0]::function[0]+0x3f>
      be:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      c2:   4d 39 ca                cmp    %r9,%r10
      c5:   0f 82 84 ff ff ff       jb     4f <wasm[0]::function[0]+0x4f>
      cb:   48 8b 47 38             mov    0x38(%rdi),%rax
      cf:   48 8b 80 b0 00 00 00    mov    0xb0(%rax),%rax
      d6:   48 83 ec 20             sub    $0x20,%rsp
      da:   48 89 f9                mov    %rdi,%rcx
      dd:   ff d0                   callq  *%rax
      df:   48 83 c4 20             add    $0x20,%rsp
      e3:   49 89 c1                mov    %rax,%r9
      e6:   e9 64 ff ff ff          jmpq   4f <wasm[0]::function[0]+0x4f>
      eb:   4c 8b 4e 10             mov    0x10(%rsi),%r9
      ef:   4d 39 cb                cmp    %r9,%r11
      f2:   0f 82 66 ff ff ff       jb     5e <wasm[0]::function[0]+0x5e>
      f8:   48 8b 4f 38             mov    0x38(%rdi),%rcx
      fc:   48 8b 91 b0 00 00 00    mov    0xb0(%rcx),%rdx
     103:   48 83 ec 20             sub    $0x20,%rsp
     107:   48 89 f9                mov    %rdi,%rcx
     10a:   ff d2                   callq  *%rdx
     10c:   48 83 c4 20             add    $0x20,%rsp
     110:   49 89 c1                mov    %rax,%r9
     113:   e9 46 ff ff ff          jmpq   5e <wasm[0]::function[0]+0x5e>
     118:   0f 0b                   ud2

The above example assigns some registers, such as ax and cx, to the check block of epoch. Actually, this is just a simple example, and more complex workloads have a significant performance impact on the box_seal.wasm, the cost has reached 25%! And after trying to manually fix the issue with epoch (Unstable), the cost was only less than 7%.
Especially for inner and outer loops, the outer loop uses r10 for storage, but the inner loop uses r11, which I cannot understand

view this post on Zulip Wasmtime GitHub notifications bot (Oct 16 2023 at 15:30):

alexcrichton commented on issue #7244:

Thanks for the report! Would you be able to share a wasm file or an example loop in source code to help reproduce this locally?

view this post on Zulip Wasmtime GitHub notifications bot (Oct 16 2023 at 15:42):

wjr-z commented on issue #7244:

Thanks for the report! Would you be able to share a wasm file or an example loop in source code to help reproduce this locally?

Thank you for your reply. In fact, I am actively searching for the reason why I am interested in optimization.
This is link to box_seal. wasm https://github.com/jedisct1/webassembly-benchmarks/blob/master/2021-Q1/wasm/box_seal.wasm
Then, this is the code for the example loop.

(module
 (export "_start" (func $_start))
 (func $_start (; 0 ;)
    (local $i i32)
    (local $i2 i32)
    i32.const 0
    local.set $i
    loop $loop
        i32.const 0
        local.set $i2
        loop $loop2
            local.get $i2
            i32.const 1
            i32.add
            local.set $i2
            local.get $i2
            i32.const 80000
            i32.lt_s
            br_if $loop2
        end $loop2
        local.get $i
        i32.const 1
        i32.add
        local.set $i
        local.get $i
        i32.const 40000
        i32.lt_s
        br_if $loop
    end $loop
 )
)

view this post on Zulip Wasmtime GitHub notifications bot (Oct 16 2023 at 15:57):

wjr-z edited a comment on issue #7244:

Thanks for the report! Would you be able to share a wasm file or an example loop in source code to help reproduce this locally?

Thank you for your reply. In fact, I am actively searching for the reason .
This is link to box_seal. wasm https://github.com/jedisct1/webassembly-benchmarks/blob/master/2021-Q1/wasm/box_seal.wasm
Then, this is the code for the example loop.

(module
 (export "_start" (func $_start))
 (func $_start (; 0 ;)
    (local $i i32)
    (local $i2 i32)
    i32.const 0
    local.set $i
    loop $loop
        i32.const 0
        local.set $i2
        loop $loop2
            local.get $i2
            i32.const 1
            i32.add
            local.set $i2
            local.get $i2
            i32.const 80000
            i32.lt_s
            br_if $loop2
        end $loop2
        local.get $i
        i32.const 1
        i32.add
        local.set $i
        local.get $i
        i32.const 40000
        i32.lt_s
        br_if $loop
    end $loop
 )
)

view this post on Zulip Wasmtime GitHub notifications bot (Oct 16 2023 at 16:07):

alexcrichton commented on issue #7244:

Thanks! Could you detail a bit more what you mean by "manually fix the issue with epoch (Unstable), the cost was only less than 7%"?

Looking at the disassembly it's not obvious to me what the issue is and how such a large win could be gained, so I'm curious how you were able to achieve it!

view this post on Zulip Wasmtime GitHub notifications bot (Oct 18 2023 at 01:17):

wjr-z commented on issue #7244:

Thanks! Could you detail a bit more what you mean by "manually fix the issue with epoch (Unstable), the cost was only less than 7%"?

Looking at the disassembly it's not obvious to me what the issue is and how such a large win could be gained, so I'm curious how you were able to achieve it!

Unfortunately, the data on the server was lost. I'll try to reproduce it next week.


Last updated: Jan 24 2025 at 00:11 UTC