On the assembly generated by create_linux_aio (in the mariadbd packages
in Ubuntu-22.04, 10.6.7-2:

(gdb) disassemble tpool::create_linux_aio,+200
Dump of assembler code from 0x5640cf2e1fb0 to 0x5640cf2e2078:
   0x00005640cf2e1fb0 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+0>:      
endbr64 
   0x00005640cf2e1fb4 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+4>:      
push   %rbp
   0x00005640cf2e1fb5 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+5>:      
mov    %rsp,%rbp
   0x00005640cf2e1fb8 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+8>:      
push   %r14
   0x00005640cf2e1fba <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+10>:     
mov    %esi,%r14d
   0x00005640cf2e1fbd <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+13>:     
push   %r13
   0x00005640cf2e1fbf <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+15>:     
mov    %rdi,%r13
   0x00005640cf2e1fc2 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+18>:     
mov    $0x158,%edi
   0x00005640cf2e1fc7 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+23>:     
push   %r12
   0x00005640cf2e1fc9 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+25>:     
sub    $0x8,%rsp
   0x00005640cf2e1fcd <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+29>:     
call   0x5640ceacb570 <_Znwm@plt>
   0x00005640cf2e1fd2 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+34>:     
mov    %r14d,%edx
   0x00005640cf2e1fd5 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+37>:     
mov    %r13,%rsi
   0x00005640cf2e1fd8 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+40>:     
mov    %rax,%rdi
   0x00005640cf2e1fdb <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+43>:     
mov    %rax,%r12
   0x00005640cf2e1fde <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+46>:     
call   0x5640cf2e1dd0 <(anonymous 
namespace)::aio_uring::aio_uring(tpool::thread_pool*, int)>
   0x00005640cf2e1fe3 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+51>:     
add    $0x8,%rsp
   0x00005640cf2e1fe7 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+55>:     
mov    %r12,%rax
   0x00005640cf2e1fea <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+58>:     
pop    %r12
   0x00005640cf2e1fec <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+60>:     
pop    %r13
   0x00005640cf2e1fee <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+62>:     
pop    %r14
   0x00005640cf2e1ff0 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+64>:     
pop    %rbp
   0x00005640cf2e1ff1 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+65>:     
ret    
   0x00005640cf2e1ff2 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+66>:     
endbr64 
   0x00005640cf2e1ff6 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+70>:     
mov    %rax,%rdi
   0x00005640cf2e1ff9 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+73>:     
mov    %rdx,%rax
   0x00005640cf2e1ffc <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+76>:     
jmp    0x5640ceb23308 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi-8121512>
   0x00005640cf2e2001 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+81>:     
endbr64 
   0x00005640cf2e2005 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+85>:     
mov    %rax,%r13
   0x00005640cf2e2008 <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+88>:     
mov    %rdx,%r14
   0x00005640cf2e200b <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi+91>:     
jmp    0x5640ceb232fa <_ZN5tpool16create_linux_aioEPNS_11thread_poolEi.cold>
--Type <RET> for more, q to quit, c to continue without paging--c
   0x00005640cf2e2010 <_ZN5tpool19thread_pool_generic17create_native_aioEi+0>:  
endbr64 
   0x00005640cf2e2014 <_ZN5tpool19thread_pool_generic17create_native_aioEi+4>:  
push   %rbp
   0x00005640cf2e2015 <_ZN5tpool19thread_pool_generic17create_native_aioEi+5>:  
mov    %rsp,%rbp
   0x00005640cf2e2018 <_ZN5tpool19thread_pool_generic17create_native_aioEi+8>:  
push   %r14
   0x00005640cf2e201a <_ZN5tpool19thread_pool_generic17create_native_aioEi+10>: 
mov    %esi,%r14d
   0x00005640cf2e201d <_ZN5tpool19thread_pool_generic17create_native_aioEi+13>: 
push   %r13
   0x00005640cf2e201f <_ZN5tpool19thread_pool_generic17create_native_aioEi+15>: 
mov    %rdi,%r13
   0x00005640cf2e2022 <_ZN5tpool19thread_pool_generic17create_native_aioEi+18>: 
mov    $0x158,%edi
   0x00005640cf2e2027 <_ZN5tpool19thread_pool_generic17create_native_aioEi+23>: 
push   %r12
   0x00005640cf2e2029 <_ZN5tpool19thread_pool_generic17create_native_aioEi+25>: 
sub    $0x8,%rsp
   0x00005640cf2e202d <_ZN5tpool19thread_pool_generic17create_native_aioEi+29>: 
call   0x5640ceacb570 <_Znwm@plt>
   0x00005640cf2e2032 <_ZN5tpool19thread_pool_generic17create_native_aioEi+34>: 
mov    %r14d,%edx
   0x00005640cf2e2035 <_ZN5tpool19thread_pool_generic17create_native_aioEi+37>: 
mov    %r13,%rsi
   0x00005640cf2e2038 <_ZN5tpool19thread_pool_generic17create_native_aioEi+40>: 
mov    %rax,%rdi
   0x00005640cf2e203b <_ZN5tpool19thread_pool_generic17create_native_aioEi+43>: 
mov    %rax,%r12
   0x00005640cf2e203e <_ZN5tpool19thread_pool_generic17create_native_aioEi+46>: 
call   0x5640cf2e1dd0 <(anonymous 
namespace)::aio_uring::aio_uring(tpool::thread_pool*, int)>
   0x00005640cf2e2043 <_ZN5tpool19thread_pool_generic17create_native_aioEi+51>: 
add    $0x8,%rsp
   0x00005640cf2e2047 <_ZN5tpool19thread_pool_generic17create_native_aioEi+55>: 
mov    %r12,%rax
   0x00005640cf2e204a <_ZN5tpool19thread_pool_generic17create_native_aioEi+58>: 
pop    %r12
   0x00005640cf2e204c <_ZN5tpool19thread_pool_generic17create_native_aioEi+60>: 
pop    %r13
   0x00005640cf2e204e <_ZN5tpool19thread_pool_generic17create_native_aioEi+62>: 
pop    %r14
   0x00005640cf2e2050 <_ZN5tpool19thread_pool_generic17create_native_aioEi+64>: 
pop    %rbp
   0x00005640cf2e2051 <_ZN5tpool19thread_pool_generic17create_native_aioEi+65>: 
ret    
   0x00005640cf2e2052 <_ZN5tpool19thread_pool_generic17create_native_aioEi+66>: 
endbr64 
   0x00005640cf2e2056 <_ZN5tpool19thread_pool_generic17create_native_aioEi+70>: 
mov    %rax,%rdi
   0x00005640cf2e2059 <_ZN5tpool19thread_pool_generic17create_native_aioEi+73>: 
mov    %rdx,%rax
   0x00005640cf2e205c <_ZN5tpool19thread_pool_generic17create_native_aioEi+76>: 
jmp    0x5640ceb23334 
<_ZN5tpool19thread_pool_generic17create_native_aioEi-8121564>
   0x00005640cf2e2061 <_ZN5tpool19thread_pool_generic17create_native_aioEi+81>: 
endbr64 
   0x00005640cf2e2065 <_ZN5tpool19thread_pool_generic17create_native_aioEi+85>: 
mov    %rax,%r13
   0x00005640cf2e2068 <_ZN5tpool19thread_pool_generic17create_native_aioEi+88>: 
mov    %rdx,%r14
   0x00005640cf2e206b <_ZN5tpool19thread_pool_generic17create_native_aioEi+91>: 
jmp    0x5640ceb23326 <_ZN5tpool19thread_pool_generic17create_native_aioEi.cold>

My assembly knowledge isn't great, but after the call to (anonymous
namespace)::aio_uring::aio_uring I'd expect some branching to identify
the exception has occurred.

I tested a simplified version
https://gist.github.com/grooverdan/f6d767a04ba5991ea2bf3de821e02e7b on
https://godbolt.org/ and
__cxa_begin_catch/__cxa_end_catch/_Unwind_Resume seem to be a standard
part of exception handling.

-- 
You received this bug notification because you are a member of Ubuntu
Touch seeded packages, which is subscribed to systemd in Ubuntu.
https://bugs.launchpad.net/bugs/1970634

Title:
  FTBFS: mariadb fails to start due to low MEMLOCK limit

Status in mariadb-10.6 package in Ubuntu:
  In Progress
Status in systemd package in Ubuntu:
  New

Bug description:
  <rbasak> ahasenack: IIRC, originally Launchpad was FTBFSing on mariadb that 
included io_uring support because upstream were doing a build time test for 
io_uring (and I think still are), which is wrong because it should be done at 
runtime since the lack of io_uring availablity at build time doesn't tell us 
about its availablity at runtime.
  <rbasak> But then the Launchpad builders got updated to a newer release and 
therefore a newer kernel that supported it.
  <rbasak> AIUI, that's how we ended up with a successful build in the Jammy 
release pocket (of 10.6).
  <ahasenack> I think the lp builders are using the focal hwe kernel
  <ahasenack> 5.4.0-something
  <ahasenack> let me check that build log
  <rbasak> But then something changed that caused this current FTBFS, and I 
haven't tracked down what that is.
  <ahasenack> hm, both are 10.6.7
  <ahasenack> release and proposed
  <rbasak> What puzzles me is that if the root cause is a memlock rlimit issue 
then why did it work before?
  <rbasak> So since there's a contradiction somewhere, maybe one or more of my 
"facts" above is wrong.
  <ahasenack> this is the current failure
  <ahasenack> 2022-04-14  8:11:49 0 [Warning] mariadbd: io_uring_queue_init() 
failed with ENOMEM: try larger memory locked limit, ulimit -l, or 
https://mariadb.com/kb/en/systemd/#configuring-limitmemlock under systemd 
(262144 bytes required)
  <ahasenack> and ulimit -l confirms that the limit is lower
  <ahasenack> Max locked memory         65536                65536              
  bytes     
  <ahasenack> just 64kbytes
  <rbasak> Yeah but then how did the release pocket build work?
  <ahasenack> either the limit was different back then
  <ahasenack> or ... stuff

To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/mariadb-10.6/+bug/1970634/+subscriptions


-- 
Mailing list: https://launchpad.net/~touch-packages
Post to     : touch-packages@lists.launchpad.net
Unsubscribe : https://launchpad.net/~touch-packages
More help   : https://help.launchpad.net/ListHelp

Reply via email to