=== If no file names and line numbers are shown below, one can run
            addr2line -Cpfie my_exefile my_line_address
    to convert `my_line_address` (e.g., 0x4a6b) into file name and line number.
    Or one can use amrex/Tools/Backtrace/parse_bt.py.

=== Please note that the line number reported by addr2line may not be accurate.
    One can use
            readelf -wl my_exefile | grep my_line_address'
    to find out the offset for that line.

 0: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x18a6f5) [0x55d0862736f5]
    amrex::BLBackTrace::print_backtrace_info(_IO_FILE*)
/raid/testing/castro-gfortran/amrex//Src/Base/AMReX_BLBackTrace.cpp:172:39

 1: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x18c346) [0x55d086275346]
    amrex::BLBackTrace::handler(int)
/raid/testing/castro-gfortran/amrex//Src/Base/AMReX_BLBackTrace.cpp:76:8

 2: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x87b4d) [0x55d086170b4d]
    amrex::Error(char const*) inlined at /raid/testing/castro-gfortran/Castro//Source/problems/Castro_bc_fill_nd.cpp:88:19 in ca_statefill(amrex::Box const&, amrex::FArrayBox&, int, int, amrex::Geometry const&, double, amrex::Vector<amrex::BCRec, std::allocator<amrex::BCRec> > const&, int, int)
/raid/testing/castro-gfortran/amrex//Src/Base/AMReX.H:101:5
ca_statefill(amrex::Box const&, amrex::FArrayBox&, int, int, amrex::Geometry const&, double, amrex::Vector<amrex::BCRec, std::allocator<amrex::BCRec> > const&, int, int)
/raid/testing/castro-gfortran/Castro//Source/problems/Castro_bc_fill_nd.cpp:88:19

 3: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x2113d1) [0x55d0862fa3d1]
    amrex::StateData::FillBoundary(amrex::Box const&, amrex::FArrayBox&, double, amrex::Geometry const&, int, int, int)
/raid/testing/castro-gfortran/amrex//Src/Amr/AMReX_StateData.cpp:553:22

 4: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x213598) [0x55d0862fc598]
    amrex::StateDataPhysBCFunct::operator()(amrex::MultiFab&, int, int, amrex::IntVect const&, double, int) [clone ._omp_fn.0]
/raid/testing/castro-gfortran/amrex//Src/Amr/AMReX_StateData.cpp:906:44

 5: /lib64/libgomp.so.1(GOMP_parallel+0x46) [0x7fc614b524c6]
    GOMP_parallel
??:0

 6: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x2118af) [0x55d0862fa8af]
    amrex::StateDataPhysBCFunct::operator()(amrex::MultiFab&, int, int, amrex::IntVect const&, double, int)
/raid/testing/castro-gfortran/amrex//Src/Amr/AMReX_StateData.cpp:867:5

 7: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x20ca23) [0x55d0862f5a23]
    std::enable_if<amrex::IsFabArray<amrex::MultiFab, void>::value, void>::type amrex::FillPatchSingleLevel<amrex::MultiFab, amrex::StateDataPhysBCFunct>(amrex::MultiFab&, amrex::IntVect const&, double, amrex::Vector<amrex::MultiFab*, std::allocator<amrex::MultiFab*> > const&, amrex::Vector<double, std::allocator<double> > const&, int, int, int, amrex::Geometry const&, amrex::StateDataPhysBCFunct&, int)
/raid/testing/castro-gfortran/amrex//Src/AmrCore/AMReX_FillPatchUtil_I.H:53:5

 8: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x201004) [0x55d0862ea004]
    std::vector<double, std::allocator<double> >::~vector() inlined at /raid/testing/castro-gfortran/amrex//Src/Base/AMReX_Vector.H:22:7 in amrex::FillPatchIterator::FillFromLevel0(double, int, int, int, int)
/usr/include/c++/9/bits/stl_vector.h:677:15
amrex::Vector<double, std::allocator<double> >::~Vector()
/raid/testing/castro-gfortran/amrex//Src/Base/AMReX_Vector.H:22:7
amrex::FillPatchIterator::FillFromLevel0(double, int, int, int, int)
/raid/testing/castro-gfortran/amrex//Src/Amr/AMReX_AmrLevel.cpp:1088:18

 9: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x2022f4) [0x55d0862eb2f4]
    amrex::FillPatchIterator::Initialize(int, double, int, int, int)
/raid/testing/castro-gfortran/amrex//Src/Amr/AMReX_AmrLevel.cpp:1002:20

10: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x202ce7) [0x55d0862ebce7]
    amrex::AmrLevel::FillPatch(amrex::AmrLevel&, amrex::MultiFab&, int, double, int, int, int, int)
/raid/testing/castro-gfortran/amrex//Src/Amr/AMReX_AmrLevel.cpp:2216:19

11: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x2a837) [0x55d086113837]
    Castro::expand_state(amrex::MultiFab&, double, int)
/raid/testing/castro-gfortran/Castro//Source/driver/Castro.cpp:4013:22

12: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x4082f) [0x55d08612982f]
    Castro::initialize_do_advance(double, double, int, int)
/raid/testing/castro-gfortran/Castro//Source/driver/Castro_advance.cpp:190:19

13: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x427f7) [0x55d08612b7f7]
    Castro::do_advance_ctu(double, double, int, int)
/raid/testing/castro-gfortran/Castro//Source/driver/Castro_advance_ctu.cpp:55:29

14: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x432e4) [0x55d08612c2e4]
    advance_status::operator=(advance_status&&) inlined at /raid/testing/castro-gfortran/Castro//Source/driver/Castro_advance_ctu.cpp:561:90 in Castro::subcycle_advance_ctu(double, double, int, int)
/raid/testing/castro-gfortran/Castro//Source/driver/Castro.H:144:8
Castro::subcycle_advance_ctu(double, double, int, int)
/raid/testing/castro-gfortran/Castro//Source/driver/Castro_advance_ctu.cpp:561:90

15: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x4181a) [0x55d08612a81a]
    double const& std::min<double>(double const&, double const&) inlined at /raid/testing/castro-gfortran/Castro//Source/driver/Castro_advance.cpp:55:92 in Castro::advance(double, double, int, int)
/usr/include/c++/9/bits/stl_algobase.h:205:14
Castro::advance(double, double, int, int)
/raid/testing/castro-gfortran/Castro//Source/driver/Castro_advance.cpp:55:92

16: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x1f063d) [0x55d0862d963d]
    amrex::Amr::timeStep(int, double, int, int, double)
/raid/testing/castro-gfortran/amrex//Src/Amr/AMReX_Amr.cpp:2054:81

17: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x1e26aa) [0x55d0862cb6aa]
    std::vector<double, std::allocator<double> >::operator[](unsigned long) inlined at /raid/testing/castro-gfortran/amrex//Src/Base/AMReX_Vector.H:34:54 in amrex::Amr::coarseTimeStep(double)
/usr/include/c++/9/bits/stl_vector.h:1042:2
amrex::Vector<double, std::allocator<double> >::operator[](unsigned long)
/raid/testing/castro-gfortran/amrex//Src/Base/AMReX_Vector.H:34:54
amrex::Amr::coarseTimeStep(double)
/raid/testing/castro-gfortran/amrex//Src/Amr/AMReX_Amr.cpp:2381:26

18: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x208dc) [0x55d0861098dc]
    main
/raid/testing/castro-gfortran/Castro//Source/driver/main.cpp:143:33

19: /lib64/libc.so.6(__libc_start_main+0xf3) [0x7fc6149601a3]
    __libc_start_main
??:0

20: ./Castro2d.gnu.TEST.TPROF.MPI.OMP.ex(+0x281fe) [0x55d0861111fe]
    _start
??:0


===== TinyProfilers ======
main()
Amr::coarseTimeStep()
Amr::timeStep()
Castro::advance()
Castro::subcycle_advance_ctu()
Castro::do_advance_ctu()
Castro::initialize_do_advance()
Castro::expand_state()
FillPatchIterator::Initialize
FillPatchSingleLevel
StateDataPhysBCFunct::()
StateData::FillBoundary(geom)