Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
129 commits
Select commit Hold shift + click to select a range
2760da7
feat(sim): add active_box parameter and m_active_box skeleton (no beh…
sbryngelson Jun 28, 2026
f257117
fix(sim): export ab_ambient from m_active_box per documented interface
sbryngelson Jun 28, 2026
2078c55
feat(sim): detect ambient state and initialize active box from IC sup…
sbryngelson Jun 28, 2026
5891b94
feat(sim): grow active box by light-cone with single device-update ch…
sbryngelson Jun 28, 2026
19c06a2
feat(sim): restrict RK update and convert window to the active box
sbryngelson Jun 28, 2026
0beb6b1
feat(sim): restrict reconstruction and Riemann windows to the active box
sbryngelson Jun 28, 2026
c79c45b
feat(sim): add debug envelope tripwire for active-box under-growth
sbryngelson Jun 29, 2026
1896baa
fix(sim): active-box tripwire checks inner margin (outer layer is fro…
sbryngelson Jun 29, 2026
a72f6b5
test(sim): golden regression for active_box on a 3D shock case
sbryngelson Jun 29, 2026
1f37c90
test(sim): strengthen active_box golden so box stays a strict subset …
sbryngelson Jun 29, 2026
e1f7ad5
fix(sim): make active-box convert bounds device-resident (GPU present…
sbryngelson Jun 29, 2026
2bb5fdc
fix(sim): active-box final-review fixes (init ab_active, tighten gate…
sbryngelson Jun 29, 2026
bbf6b2a
feat(sim): add load_weight_wrt param and m_load_weight skeleton (no b…
sbryngelson Jun 29, 2026
e474a22
feat(sim): load_weight base + active-box contributor with field output
sbryngelson Jun 29, 2026
796f884
feat(sim): per-rank load-imbalance metric
sbryngelson Jun 29, 2026
fa1629b
feat(sim): bubble (EE/EL) load-weight contributors
sbryngelson Jun 29, 2026
e54c161
fix(sim): gate bubble load-weight contributions by the active box
sbryngelson Jun 29, 2026
7c2fb22
feat(sim): IB load-weight contributor
sbryngelson Jun 29, 2026
a12b5f5
feat(sim): phase-change Newton-iteration load-weight contributor
sbryngelson Jun 29, 2026
14b837c
fix(sim): load-weight metric on parallel_io path + EE reads q_cons (f…
sbryngelson Jun 29, 2026
0161fac
feat(sim): add sfc_partition params and m_sfc_partition skeleton (no …
sbryngelson Jun 29, 2026
5b30010
fix(sim): export m_sfc_partition state + guard partition_tile_size>=1
sbryngelson Jun 29, 2026
71b503d
feat(sim): aggregate per-cell load weight into global tile weights
sbryngelson Jun 29, 2026
0d2ac75
feat(sim): Morton space-filling-curve tile ordering
sbryngelson Jun 29, 2026
0ba87e2
feat(sim): chains-on-chains balanced contiguous SFC partition
sbryngelson Jun 29, 2026
f7617e8
feat(sim): report SFC-partition predicted imbalance + call wiring
sbryngelson Jun 29, 2026
2795e26
fix(sim): self-contained SFC report (current + predicted + gain)
sbryngelson Jun 29, 2026
6df9c1f
spike(sim): prove weighted re-decompose + re-read mechanism
sbryngelson Jun 30, 2026
5570a71
feat(sim): weighted-split function for load-balanced decomposition
sbryngelson Jun 30, 2026
8c01acb
feat(sim): global axis marginals from per-cell load weight
sbryngelson Jun 30, 2026
b992103
feat(sim): wire load_balance weighted decomposition (param, checks, o…
sbryngelson Jun 30, 2026
c00c8b2
feat(sim): minimal probe read for functional weighted decomposition
sbryngelson Jun 30, 2026
69227fe
fix(sim): load_balance min-cells floor only applies to axes split acr…
sbryngelson Jun 30, 2026
ffadfe0
fix(sim): conforming sizes_glb/loc assignment in probe; drop supersed…
sbryngelson Jun 30, 2026
c43c02a
fix(sim): scope num_procs_x/y/z to simulation (post_process build), a…
sbryngelson Jun 30, 2026
95398eb
feat(sim): rank_time_wrt param + m_rank_timing per-rank RHS-time diag…
sbryngelson Jun 30, 2026
adacca1
feat(sim): wire per-rank RHS-time diagnostic into stepper and data ou…
sbryngelson Jun 30, 2026
b637627
fix(sim): drop EE bubble load-weight term (calibration: K_bub*void ov…
sbryngelson Jun 30, 2026
f8cfe78
feat(sim): broaden rank-timing to include phase-change relaxation (t_…
sbryngelson Jun 30, 2026
cc7882d
fix(sim): rank-timing measures compute only (exclude halo exchange) +…
sbryngelson Jun 30, 2026
21c60ff
feat(sim): hybrid_weno + hybrid_weno_eps params and checks
sbryngelson Jun 30, 2026
99fd63e
feat(sim): WENO discontinuity sensor (density+pressure Jameson, stenc…
sbryngelson Jun 30, 2026
f94573c
feat(sim): hybrid WENO branch (linear-optimal in smooth cells) + sens…
sbryngelson Jun 30, 2026
0d1337e
fix(sim): allocate hybrid-WENO sensor scratch once (module-level weno…
sbryngelson Jun 30, 2026
33bd3aa
fix(sim): hybrid-WENO covers buffered domain (halo flagging) + PROHIB…
sbryngelson Jul 1, 2026
7efb010
feat(sim): hybrid_riemann + hybrid_smooth_flux params, defaults, and …
sbryngelson Jul 1, 2026
1ec23ae
feat(sim): generalize discontinuity sensor to velocity+volume-fractio…
sbryngelson Jul 1, 2026
08502db
feat(sim): hybrid_riemann cheap central/Rusanov flux in the 5-equatio…
sbryngelson Jul 1, 2026
9e484ac
feat(sim): hybrid_riemann cheap flux in the 6-equation HLLC block
sbryngelson Jul 1, 2026
5082b53
fix(sim): prohibit hybrid_riemann/hybrid_weno with non-WENO recon, we…
sbryngelson Jul 1, 2026
74b5877
feat(common): add m_box (t_box + partition arithmetic); relocate f_we…
sbryngelson Jul 1, 2026
f727133
refactor(common): s_mpi_decompose computes equal split via m_box (t_b…
sbryngelson Jul 1, 2026
ac2edef
test(sim): load_balance manual validation; document diagnostic gate
sbryngelson Jul 1, 2026
de24440
fix(common): explicit allocate for equal-split offsets (Intel noreall…
sbryngelson Jul 1, 2026
352f564
feat(sim): amr param + static-patch spec + SP1 gate (default off)
sbryngelson Jul 2, 2026
69f5c36
feat(sim): m_amr two-level static hierarchy (inert refined level-1); …
sbryngelson Jul 2, 2026
3bc4d4b
feat(sim): AMR conservative restriction + conservative-linear prolong…
sbryngelson Jul 2, 2026
66b209d
feat(sim): AMR fine-advance infrastructure (stage storage, globals sw…
sbryngelson Jul 2, 2026
ff1d75a
feat(sim): AMR no-subcycle two-level advance (per-stage coupling, end…
sbryngelson Jul 2, 2026
434eec1
feat(sim): AMR refluxing - per-stage flux registers close conservatio…
sbryngelson Jul 2, 2026
8269e79
refactor(sim): AMR region-based indexing + fixed max-size preallocati…
sbryngelson Jul 2, 2026
622b37b
feat(sim): AMR dynamic regrid - gradient tagging, padded bounding box…
sbryngelson Jul 2, 2026
e015a34
feat(sim): AMR subcycling groundwork - accumulating flux registers, s…
sbryngelson Jul 2, 2026
5f65b62
feat(sim): AMR subcycling - coarse at case dt, two dt/2 fine substeps…
sbryngelson Jul 2, 2026
8e1f8c3
fix(sim): prohibit amr + acoustic_source (dt-dependent RHS source, un…
sbryngelson Jul 2, 2026
247b2f3
feat(sim): AMR multi-rank owner model - containment, global-local ind…
sbryngelson Jul 2, 2026
725f50b
feat(sim): AMR multi-rank regrid - allreduced tag box, owner-window c…
sbryngelson Jul 2, 2026
2c1dd4e
refactor(sim): AMR copy-based coordinate swap (GPU-safe semantics, be…
sbryngelson Jul 2, 2026
2048cdb
feat(sim): AMR on GPU builds - device-resident fine fields, transfer-…
sbryngelson Jul 3, 2026
cc9719f
chore: AMR upstream hygiene - docs, python validation, message cleanu…
sbryngelson Jul 3, 2026
b203dc8
feat(sim): AMR GPU kernel-ported coupling (M2) - device-resident regi…
sbryngelson Jul 3, 2026
41530c4
feat(sim): AMR mirror-decomposed fine level (T1) - spanning patches, …
sbryngelson Jul 3, 2026
316c28b
feat(sim): AMR rank-local regrid under mirror decomposition (T2) - sp…
sbryngelson Jul 3, 2026
03b5951
feat(sim): AMR-weighted decomposition (SP7c) - fine-work-aware load_b…
sbryngelson Jul 3, 2026
a1a7e3a
Merge remote-tracking branch 'upstream/master' into up/mega
sbryngelson Jul 3, 2026
2b1e8a9
test(sim): AMR 3D validation - free-stream/blast/spanning/subcycle ga…
sbryngelson Jul 3, 2026
8dddd82
feat(sim): multi-fluid AMR (SP9a) - per-fluid conservative reflux, su…
sbryngelson Jul 3, 2026
9e936de
merge: multi-fluid AMR (SP9a) with 3D validation
sbryngelson Jul 3, 2026
a57dcb6
merge: 3D validation + multi-fluid AMR (SP9a) into the upstream PR br…
sbryngelson Jul 3, 2026
9064ecd
feat(sim): AMR restart - fine-level save/restore with regridded-box p…
sbryngelson Jul 3, 2026
b8a14ae
merge: AMR restart (SP10) into the PR branch
sbryngelson Jul 3, 2026
3003068
feat(sim): viscous AMR (SP11) - viscous flux registers, c/f-matched t…
sbryngelson Jul 3, 2026
6129592
fix(sim): AMR fine ghost coordinates for viscous stencil (SP11 np=2 e…
sbryngelson Jul 3, 2026
3c6e77d
merge: viscous AMR (SP11) + fine-ghost-coordinate fix into the PR branch
sbryngelson Jul 3, 2026
931470d
refactor(sim): AMR patch slots (amr_fine -> amr_slots, fixed pool arr…
sbryngelson Jul 3, 2026
bc32128
merge: AMR patch-slot infrastructure (SP12a T1) into PR branch
sbryngelson Jul 3, 2026
8bb32ed
feat(sim): AMR multi-patch - Berger-Rigoutsos clustering, min-separat…
sbryngelson Jul 4, 2026
11d46e3
refactor: rename AMR "patch" -> "block" (params, symbols, docs) to di…
sbryngelson Jul 4, 2026
fc65bad
merge: AMR multi-patch (SP12a) + patch->block rename into PR branch
sbryngelson Jul 4, 2026
7bf7bee
feat(sim): Euler-Euler bubbles AMR (SP13) - realizability-preserving …
sbryngelson Jul 4, 2026
00c9378
merge: Euler-Euler bubbles AMR (SP13) into PR branch
sbryngelson Jul 4, 2026
7bc7cde
feat(sim): phase-change (relax) AMR (SP15) - per-block pressure relax…
sbryngelson Jul 4, 2026
17a8e51
merge: phase-change (relax) AMR (SP15) into PR branch
sbryngelson Jul 4, 2026
a429c68
test(sim): AMR cross-feature golden coverage (viscous+multifluid+mult…
sbryngelson Jul 4, 2026
b816bc3
merge: AMR GPU-correctness + cross-feature golden coverage (blind spo…
sbryngelson Jul 4, 2026
5b72e1d
docs(sim): document AMR+surface_tension limitation as an explicit pro…
sbryngelson Jul 4, 2026
86c1038
feat(sim): chemistry AMR (SP16) - species sum/positivity prolongation…
sbryngelson Jul 4, 2026
37265de
merge: chemistry AMR (SP16, multi-rank) + surface-tension limitation …
sbryngelson Jul 4, 2026
267660c
docs: AMR feature documentation page
sbryngelson Jul 4, 2026
8354b1f
merge: AMR documentation page into PR branch
sbryngelson Jul 4, 2026
cdf9239
feat(sim): chemistry diffusion under AMR (SP17) - flux_src reflux at …
sbryngelson Jul 4, 2026
dbb1331
feat(sim): non-polytropic + polydisperse bubbles AMR (SP18) - per-blo…
sbryngelson Jul 4, 2026
f16d52d
docs: update AMR support matrix - chemistry diffusion + non-polytropi…
sbryngelson Jul 4, 2026
5522823
merge: finish chemistry (diffusion, SP17) + bubbles (non-polytropic/p…
sbryngelson Jul 4, 2026
1a5193d
feat(sim): QBMM bubbles AMR (SP19) - fine-resolution moment inversion…
sbryngelson Jul 4, 2026
21d5965
feat(sim): static immersed-boundary AMR (SP20) - per-block fine IB ma…
sbryngelson Jul 4, 2026
49db985
fix(sim): gate IB body straddling a rank seam under AMR (fine-IB imag…
sbryngelson Jul 4, 2026
e035a10
docs(amr): support matrix for QBMM-polytropic + static IB; seam-strad…
sbryngelson Jul 4, 2026
2dacb4b
fix(test): remove stray merge marker left in cases.py during SP20 che…
sbryngelson Jul 4, 2026
83a6f01
style: format m_checker AMR prohibit block after SP19/SP20 fold
sbryngelson Jul 4, 2026
b4463ef
merge: QBMM (SP19) + static IB (SP20) AMR into PR branch
sbryngelson Jul 4, 2026
2c43eb8
fix(test): restore dropped cases.append/stack.pop for QBMM AMR golden…
sbryngelson Jul 4, 2026
01d640b
fix(test): restore dropped cases.append/stack.pop for QBMM AMR golden…
sbryngelson Jul 4, 2026
87ef798
fix(sim): device-attach IB fine-swap under AMR GPU - detach/attach ib…
sbryngelson Jul 4, 2026
1f9a9bc
fix(sim): device-attach IB fine-swap under AMR GPU - detach/attach ib…
sbryngelson Jul 4, 2026
9fbe760
feat(sim): prescribed-motion moving IB under AMR (SP21) - per-substep…
sbryngelson Jul 4, 2026
53220a1
test(amr): moving-IB golden (SP21, 13945217) + non-poly bubble GPU to…
sbryngelson Jul 4, 2026
781aac9
feat(sim): prescribed-motion moving IB under AMR (SP21) - per-substep…
sbryngelson Jul 4, 2026
ac06c72
test(amr): moving-IB golden (SP21, 13945217) + non-poly bubble GPU to…
sbryngelson Jul 4, 2026
8192acf
fix(amr): restart sys_size guard (3-int header) + AMR restart golden …
sbryngelson Jul 4, 2026
e2d9dfe
feat(post): AMR-aware post_process - fine blocks as Silo/binary overl…
sbryngelson Jul 5, 2026
2e955f8
fix(amr): reconcile post-process reader to 3-int restart header + non…
sbryngelson Jul 5, 2026
ea56daa
merge: shippability batch - restart hardening + AMR-aware post_proces…
sbryngelson Jul 5, 2026
cf3733f
fix(sim): IB-AMR OMP-offload crash - explicit copyin(ib_markers%sf) o…
sbryngelson Jul 5, 2026
4d5df1e
merge: IB-AMR OpenMP-offload fix (copyin ib_markers - validated CPU/A…
sbryngelson Jul 5, 2026
09a4d5d
cleanup(gpu): drop the OMP attach/detach macro change - copyin(ib_mar…
sbryngelson Jul 5, 2026
2e8ffe6
merge: IB-OMP fix cleanup (copyin alone; drop shared omp_macros change)
sbryngelson Jul 5, 2026
59d6e86
fix(post): seed q_T for AMR fine-block chemistry cons->prim (was unin…
sbryngelson Jul 5, 2026
d0d20b2
fix(sim): clamp interior-only fd_coeff cell index in mibm IB-drag str…
sbryngelson Jul 5, 2026
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .typos.toml
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@ TKE = "TKE"
HSA = "HSA"
infp = "infp"
Sur = "Sur"
thi = "thi" # AMR clustering local: tagged-box hi index (tlo/thi)
alo = "alo" # AMR clustering local: accepted-box lo array (alo/ahi)
thr = "thr" # AMR clustering local: min-separation merge threshold
chioces = "chioces" # typo for "choices" - tests constraint key validation
reqires = "reqires" # typo for "requires" - tests dependency key validation
choises = "choises" # appears in comment explaining validation purpose
Expand Down
310 changes: 310 additions & 0 deletions docs/documentation/amr.md

Large diffs are not rendered by default.

180 changes: 180 additions & 0 deletions docs/documentation/case.md

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions docs/documentation/readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ Welcome to the Multi-component Flow Code (MFC) documentation.

- @ref architecture "Code Architecture" - How the source code is organized, data flow, and module map
- @ref expectedPerformance "Performance" - Optimization and benchmarks
- @ref amr "Adaptive Mesh Refinement" - Block-structured AMR: algorithm, physics support, and parameters
- @ref gpuParallelization "GPU Parallelization" - GPU macro API (developer reference)
- @ref docker "Containers" - Docker usage
- @ref troubleshooting "Troubleshooting" - Debugging and common issues
Expand Down
10 changes: 9 additions & 1 deletion docs/module_categories.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
"category": "Solver Core",
"modules": [
"m_rhs",
"m_active_box",
"m_time_steppers",
"m_weno",
"m_riemann_solvers",
Expand Down Expand Up @@ -58,7 +59,11 @@
"m_start_up",
"m_data_output",
"m_data_input",
"m_delay_file_access"
"m_delay_file_access",
"m_load_weight",
"m_load_balance",
"m_sfc_partition",
"m_rank_timing"
]
},
{
Expand All @@ -69,6 +74,9 @@
"m_global_parameters_common",
"m_mpi_common",
"m_mpi_proxy",
"m_box",
"m_amr",
"m_amr_registers",
"m_constants",
"m_precision_select",
"m_helper",
Expand Down
4 changes: 4 additions & 0 deletions src/common/m_boundary_common.fpp
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,10 @@ contains
type(integer_field), dimension(1:num_dims,1:2), intent(in) :: bc_type
type(scalar_field), optional, intent(inout) :: q_T_sf

#ifdef MFC_SIMULATION
if (amr_in_fine_advance) return ! AMR fine block: ghosts pre-filled from the coarse level
#endif

call s_populate_bc_direction(1, -1, bc_x, bc_type(1, 1), q_prim_vf, pb_in, mv_in, q_T_sf)
call s_populate_bc_direction(1, 1, bc_x, bc_type(1, 2), q_prim_vf, pb_in, mv_in, q_T_sf)

Expand Down
85 changes: 85 additions & 0 deletions src/common/m_box.fpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
!>
!!@file
!!@brief Contains module m_box

#:include 'macros.fpp'

!> @brief Owned domain-decomposition Box abstraction and partition arithmetic (v1: one box per rank).
module m_box

use m_derived_types, only: t_box
use m_global_parameters, only: wp

implicit none

private
public :: t_box, f_equal_splits, f_weighted_splits, f_box_from_splits

contains

!> Cumulative equal-cell offsets for g cells over n_parts ranks: off(r) = r*(g/n_parts) + min(r, mod(g,n_parts)). Reproduces
!! MFC's block distribution (remainder to the first ranks) exactly. Pure integer path.
pure function f_equal_splits(g, n_parts) result(off)

integer, intent(in) :: g, n_parts
integer, dimension(0:n_parts) :: off
integer :: q, rem, r

q = g/n_parts
rem = mod(g, n_parts)
do r = 0, n_parts
off(r) = r*q + min(r, rem)
end do

end function f_equal_splits

!> Cumulative offsets splitting marginal w into n_parts contiguous chunks of near-equal weight, each >= l_min cells. off(0)=0,
!! off(n_parts)=size(w). Feasibility (size(w) >= n_parts*l_min) is the caller's responsibility (pure; no abort).
pure function f_weighted_splits(w, n_parts, l_min) result(off)

real(wp), dimension(0:), intent(in) :: w
integer, intent(in) :: n_parts, l_min
integer, dimension(0:n_parts) :: off
real(wp) :: csum, total
integer :: g, i, r

g = size(w)
off(0) = 0
off(n_parts) = g
if (n_parts == 1) return
total = sum(w)
r = 1
csum = 0._wp
do i = 0, g - 1
csum = csum + w(i)
do while (r < n_parts .and. csum >= real(r, wp)*total/real(n_parts, wp))
off(r) = i + 1
r = r + 1
end do
end do
do while (r < n_parts)
off(r) = g; r = r + 1
end do
do r = 1, n_parts - 1
if (off(r) < r*l_min) off(r) = r*l_min
if (off(r) > g - (n_parts - r)*l_min) off(r) = g - (n_parts - r)*l_min
if (off(r) <= off(r - 1)) off(r) = off(r - 1) + l_min
end do

end function f_weighted_splits

!> Assemble this rank's box from per-axis cumulative offsets and the rank's Cartesian coords (0-based). lo(d) =
!! off_d(coords(d)); hi(d) = off_d(coords(d)+1) - 1. Works for collapsed axes (off_d = [0,1] -> lo=hi=0).
pure function f_box_from_splits(off_x, off_y, off_z, coords) result(box)

integer, dimension(0:), intent(in) :: off_x, off_y, off_z
integer, intent(in) :: coords(3)
type(t_box) :: box

box%lo(1) = off_x(coords(1)); box%hi(1) = off_x(coords(1) + 1) - 1
box%lo(2) = off_y(coords(2)); box%hi(2) = off_y(coords(2) + 1) - 1
box%lo(3) = off_z(coords(3)); box%hi(3) = off_z(coords(3) + 1) - 1

end function f_box_from_splits

end module m_box
7 changes: 7 additions & 0 deletions src/common/m_derived_types.fpp
Original file line number Diff line number Diff line change
Expand Up @@ -537,4 +537,11 @@ module m_derived_types
real(wp), dimension(1:num_fluids_max) :: perturb_dens_scale
real(wp), dimension(1:num_fluids_max,3) :: perturb_dens_offset
end type simplex_noise_params

!> An index-space rectangle in global cell indices. In v1, one t_box = one rank's subdomain. Flat leaf: no allocatable/pointer
!! components, host-only, never namelist/broadcast.
type t_box
integer :: lo(3) !< global low cell index per axis (x,y,z)
integer :: hi(3) !< global high cell index per axis
end type t_box
end module m_derived_types
12 changes: 7 additions & 5 deletions src/common/m_global_parameters_common.fpp
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,7 @@ module m_global_parameters_common
$:GPU_DECLARE(create='[hyperelasticity, elasticity, low_Mach]')
$:GPU_DECLARE(create='[cont_damage, hyper_cleaning]')
$:GPU_DECLARE(create='[relax, relax_model, palpha_eps, ptgalpha_eps]')
$:GPU_DECLARE(create='[load_weight_wrt]')
$:GPU_DECLARE(create='[down_sample]')
$:GPU_DECLARE(create='[fd_order]')
$:GPU_DECLARE(create='[rhoref, pref]')
Expand Down Expand Up @@ -348,6 +349,11 @@ contains

allocate (proc_coords(1:num_dims))

#ifdef MFC_MPI
! start_idx is always needed (e.g. for sfc_partition_wrt); parallel I/O setup below is optional.
allocate (start_idx(1:num_dims))
#endif

if (parallel_io .neqv. .true.) return

#ifdef MFC_MPI
Expand All @@ -359,8 +365,6 @@ contains

! Option for UNIX file system (Hooke/Thomson) WRITE(mpiiofs, '(A)') '/ufs_' mpiiofs = TRIM(mpiiofs) mpi_info_int =
! MPI_INFO_NULL

allocate (start_idx(1:num_dims))
#endif

end subroutine s_initialize_parallel_io_common
Expand All @@ -373,9 +377,7 @@ contains
deallocate (proc_coords)

#ifdef MFC_MPI
if (parallel_io) then
deallocate (start_idx)
end if
deallocate (start_idx)
#endif

end subroutine s_finalize_global_parameters_common
Expand Down
Loading
Loading