diff --git a/cfgs/C1D_PAPA/MY_SRC/usrdef_nam.F90 b/cfgs/C1D_PAPA/MY_SRC/usrdef_nam.F90
index 6269b43bfec8a0923318896ce25de900b9ffe001..8ada9194cf7727543bd43fe577acae23152a83e0 100644
--- a/cfgs/C1D_PAPA/MY_SRC/usrdef_nam.F90
+++ b/cfgs/C1D_PAPA/MY_SRC/usrdef_nam.F90
@@ -84,8 +84,8 @@ CONTAINS
          WRITE(numout,*) '~~~~~~~~~~~ '
          WRITE(numout,*) '   Namelist namusr_def : C1 case'
          WRITE(numout,*) '      C1D domain = 1 x 1 x 75 grid-points                '
-         WRITE(numout,*) '         resulting global domain size :        jpiglo = ', kpi
-         WRITE(numout,*) '                                               jpjglo = ', kpj
+         WRITE(numout,*) '         resulting global domain size :        Ni0glo = ', kpi
+         WRITE(numout,*) '                                               Nj0glo = ', kpj
          WRITE(numout,*) '                                               jpkglo = ', kpk
          WRITE(numout,*) '   '
       ENDIF
diff --git a/sette/input_C1D_PAPA.cfg b/sette/input_C1D_PAPA.cfg
new file mode 100644
index 0000000000000000000000000000000000000000..0ffa202563cb87f1fc0cc1d7342f64412fc12a9a
--- /dev/null
+++ b/sette/input_C1D_PAPA.cfg
@@ -0,0 +1 @@
+C1D_PAPA_v4.2.0.tar.gz C1D_PAPA_v4.2.0
diff --git a/sette/param.default b/sette/param.default
index fe0b2d155c911dcfc127a5b561209d3c532da164..c9cca2fde1bb5c5a98f1ab8d5a97db68f6c1abb9 100644
--- a/sette/param.default
+++ b/sette/param.default
@@ -63,7 +63,7 @@ LC_MESSAGES=en_US
 #
 # LIST OF CONFIGURATIONS
 # to be updated if you added an new configuration in sette_test-cases.sh or sette_reference-configuration.sh
-TEST_CONFIG_AVAILABLE=(ORCA2_ICE_PISCES ORCA2_OFF_PISCES AMM12 AGRIF_DEMO WED025 GYRE_PISCES ORCA2_SAS_ICE ORCA2_ICE_OBS SWG ICE_AGRIF OVERFLOW LOCK_EXCHANGE VORTEX ISOMIP+)
+TEST_CONFIG_AVAILABLE=(ORCA2_ICE_PISCES ORCA2_OFF_PISCES AMM12 AGRIF_DEMO WED025 GYRE_PISCES ORCA2_SAS_ICE ORCA2_ICE_OBS C1D_PAPA SWG ICE_AGRIF OVERFLOW LOCK_EXCHANGE VORTEX ISOMIP+)
 if [ -z "${TEST_CONFIGS}" ]; then
   export TEST_CONFIGS=(${SETTE_TEST_CONFIGS[@]:-${TEST_CONFIG_AVAILABLE[@]}})
 fi
diff --git a/sette/sette_reference-configurations.sh b/sette/sette_reference-configurations.sh
index d6d11b9f4482a386c8e62917213037c6ad43b709..ddaa5e99710f31d7e7b04e0e30e41afd86aeae78 100755
--- a/sette/sette_reference-configurations.sh
+++ b/sette/sette_reference-configurations.sh
@@ -1702,6 +1702,89 @@ fi
 fi
 
 
+# -----------
+# C1D_PAPA
+# -----------
+if [ ${config} == "C1D_PAPA" ] ; then
+    SETTE_CONFIG=${config}${SETTE_STG}
+    if [[ -n "${NEMO_DEBUG}" || ${CMP_NAM_L} =~ ("debug"|"dbg") ]]
+    then
+	ITEND=240   # 1 day
+    else
+	ITEND=87600 # 365 days
+    fi
+    ITRST=$( printf "%08d" $(( ${ITEND} / 2 )) )
+
+if [ ${DO_COMPILE} -eq 1 ] ;  then
+    cd ${MAIN_DIR}
+    #
+    # syncronisation if target directory/file exist (not done by makenemo)
+    clean_config ${CMP_DIR:-${CONFIG_DIR0}}/${SETTE_CONFIG}
+    sync_config  ${CONFIG_DIR0}/${config} ${CMP_DIR:-${CONFIG_DIR0}}/${SETTE_CONFIG}
+    #
+    # C1D_PAPA uses linssh so remove key_qco if added by default
+    ./makenemo -m ${CMP_NAM} -n ${SETTE_CONFIG} -r ${config} ${CUSTOM_DIR:+-t ${CMP_DIR}} -k 0 ${NEMO_DEBUG} -j ${CMPL_CORES} add_key "${ADD_KEYS/key_qco/}" del_key "${DEL_KEYS}"
+fi
+
+## Restartability tests for C1D_PAPA
+if [ ${DO_RESTART} == "1" ] ;  then
+    export TEST_NAME="LONG"
+    cd ${SETTE_DIR}
+    . ./prepare_exe_dir.sh
+    set_valid_dir
+    clean_valid_dir
+    JOB_FILE=${EXE_DIR}/run_job.sh
+    NPROC=1
+    if [ -f ${JOB_FILE} ] ; then \rm ${JOB_FILE} ; fi
+    cd ${EXE_DIR}
+    set_namelist namelist_cfg cn_exp \"C1DPAPA_LONG\"
+    set_namelist namelist_cfg nn_it000 1
+    set_namelist namelist_cfg nn_itend ${ITEND}
+    set_namelist namelist_cfg nn_stock $(( ${ITEND} / 2 ))
+    set_namelist namelist_cfg jpni 1
+    set_namelist namelist_cfg jpnj 1
+    set_namelist namelist_cfg sn_cfctl%l_runstat .true.
+    set_namelist namelist_cfg sn_cfctl%l_trcstat .true.
+    set_namelist_opt namelist_cfg ln_timing ${USING_TIMING} .true. .false.
+    set_namelist_opt namelist_cfg nn_hls ${USING_EXTRA_HALO} 3 1
+    set_namelist_opt namelist_cfg nn_comm ${USING_COLLECTIVES} 2 1
+    set_namelist_opt namelist_cfg ln_tile ${USING_TILING} .true. .false.
+    set_xio_using_server iodef.xml ${USING_MPMD}
+    cd ${SETTE_DIR}
+    . ./prepare_job.sh input_${config}.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS} ${NEMO_VALID}
+
+    cd ${SETTE_DIR}
+    export TEST_NAME="SHORT"
+    . ./prepare_exe_dir.sh
+    set_valid_dir
+    clean_valid_dir
+    cd ${EXE_DIR}
+    set_namelist namelist_cfg cn_exp \"C1DPAPA_SHORT\"
+    set_namelist namelist_cfg nn_it000 $(( ${ITEND} / 2 + 1 ))
+    set_namelist namelist_cfg nn_itend ${ITEND}
+    set_namelist namelist_cfg nn_stock $(( ${ITEND} / 2 ))
+    set_namelist namelist_cfg ln_rstart .true.
+    set_namelist namelist_cfg nn_rstctl 2
+    set_namelist namelist_cfg jpni 1
+    set_namelist namelist_cfg jpnj 1
+    set_namelist namelist_cfg sn_cfctl%l_runstat .true.
+    set_namelist namelist_cfg sn_cfctl%l_trcstat .true.
+    set_namelist namelist_cfg cn_ocerst_in \"C1DPAPA_LONG_${ITRST}_restart\"
+    set_namelist_opt namelist_cfg nn_hls ${USING_EXTRA_HALO} 3 1
+    set_namelist_opt namelist_cfg nn_comm ${USING_COLLECTIVES} 2 1
+    set_namelist_opt namelist_cfg ln_tile ${USING_TILING} .true. .false.
+    set_xio_using_server iodef.xml ${USING_MPMD}
+    ln -sf ../LONG/C1DPAPA_LONG_${ITRST}_restart.nc .
+    cd ${SETTE_DIR}
+    . ./prepare_job.sh input_${config}.cfg $NPROC ${TEST_NAME} ${MPIRUN_FLAG} ${JOB_FILE} ${NUM_XIOSERVERS} ${NEMO_VALID}
+    cd ${SETTE_DIR}
+    . ./fcm_job.sh $NPROC ${JOB_FILE} ${INTERACT_FLAG} ${MPIRUN_FLAG}
+
+fi
+
+fi
+
+
 done
 #
 # Return to SETTE_DIR (last fcm_job.sh will have moved to EXE_DIR)
diff --git a/sette/sette_rpt.sh b/sette/sette_rpt.sh
index a86b30cc8716d6899cff9fbb3a965f1410b6cc2d..06ab2e9e640313f80420f45f32f372e07f40527f 100755
--- a/sette/sette_rpt.sh
+++ b/sette/sette_rpt.sh
@@ -655,7 +655,7 @@ do
 # Reproducibility tests
  echo ""
  echo "   !----repro----!   "
- for repro_test in ${TEST_CONFIGS[@]}
+ for repro_test in ${TEST_CONFIGS[@]/C1D_PAPA}
  do
    if [[ ${repro_test} != *"OVERFLOW"* && ${repro_test} != *"LOCK_EXCHANGE"* ]]; then
       reprotest $NEMO_VALID $repro_test $pass
diff --git a/src/OCE/LBC/lbc_lnk_neicoll_generic.h90 b/src/OCE/LBC/lbc_lnk_neicoll_generic.h90
index 1ab6c1b1ff4079f8162077f31fc438557d5402a6..4738929bf6d82430bf839c6ad26a8d0b6e94db75 100644
--- a/src/OCE/LBC/lbc_lnk_neicoll_generic.h90
+++ b/src/OCE/LBC/lbc_lnk_neicoll_generic.h90
@@ -274,8 +274,8 @@
                DO jl = 1, ipl(jf)  ;  DO jk = 1, ipk(jf)  ;  DO jj = 1,isizej(jn,jf)  ;  DO ji = 1,isizei(jn,jf)
                   ii1 = ishti1 +       ji                * isgni1
                   ij1 = ishtj1 +       jj                * isgnj1
-                  ii2 = ishti2 + ( MOD(ji-1, Ni_0) + 1 ) * isgni2   ! warning: Ni_0 my be smaller than isizei(jn,jf)
-                  ij2 = ishtj2 + ( MOD(jj-1, Nj_0) + 1 ) * isgnj2   ! warning: Nj_0 my be smaller than isizej(jn,jf)
+                  ii2 = ishti2 + ( MOD(ji-1, Ni_0) + 1 ) * isgni2   ! warning: Ni_0 might be smaller than isizei(jn,jf)
+                  ij2 = ishtj2 + ( MOD(jj-1, Nj_0) + 1 ) * isgnj2   ! warning: Nj_0 might be smaller than isizej(jn,jf)
                   ptab(jf)%pt4d(ii1,ij1,jk,jl) = ptab(jf)%pt4d(ii2,ij2,jk,jl)
                END DO   ;   END DO   ;   END DO   ;   END DO
                !
diff --git a/src/OCE/LBC/lbc_lnk_pt2pt_generic.h90 b/src/OCE/LBC/lbc_lnk_pt2pt_generic.h90
index 118aa5c54198b7cc56a307f87edd439f8486279d..051eec61fc06a64c75c869925ab062e38f165f25 100644
--- a/src/OCE/LBC/lbc_lnk_pt2pt_generic.h90
+++ b/src/OCE/LBC/lbc_lnk_pt2pt_generic.h90
@@ -344,8 +344,8 @@
          DO jl = 1, ipl(jf)  ;  DO jk = 1, ipk(jf)  ;  DO jj = 1,isizej(jn,jf)  ;  DO ji = 1,isizei(jn,jf)
             ii1 = ishti1 +       ji                * isgni1
             ij1 = ishtj1 +       jj                * isgnj1
-            ii2 = ishti2 + ( MOD(ji-1, iisz) + 1 ) * isgni2   ! warning: iisz my be smaller than isizei(jn,jf)
-            ij2 = ishtj2 + ( MOD(jj-1, Nj_0) + 1 ) * isgnj2   ! warning: Nj_0 my be smaller than isizej(jn,jf)
+            ii2 = ishti2 + ( MOD(ji-1, iisz) + 1 ) * isgni2   ! warning: iisz might be smaller than isizei(jn,jf)
+            ij2 = ishtj2 + ( MOD(jj-1, Nj_0) + 1 ) * isgnj2   ! warning: Nj_0 might be smaller than isizej(jn,jf)
             ptab(jf)%pt4d(ii1,ij1,jk,jl) = ptab(jf)%pt4d(ii2,ij2,jk,jl)
          END DO   ;   END DO   ;   END DO   ;   END DO
          !
diff --git a/src/OCE/LBC/mppini.F90 b/src/OCE/LBC/mppini.F90
index ec314a26f536687484d4cd52cb6444f97162e6da..853aaa9e47cc5284c3cced9124c0a6d11e3848fa 100644
--- a/src/OCE/LBC/mppini.F90
+++ b/src/OCE/LBC/mppini.F90
@@ -630,7 +630,7 @@ CONTAINS
 #else
       klci(1:iresti      ,:) = kimax
       klci(iresti+1:knbi ,:) = kimax-1
-      IF( MINVAL(klci) < 3*khls ) THEN
+      IF( MINVAL(klci) < 3*khls .AND. knbi > 1 ) THEN   ! if we do MPI communications along i (knbi > 1)
          WRITE(ctmp1,*) '   mpp_basesplit: minimum value of jpi must be >= ', 3*khls
          WRITE(ctmp2,*) '   We have ', MINVAL(klci)
          CALL ctl_stop( 'STOP', ctmp1, ctmp2 )
@@ -648,7 +648,7 @@ CONTAINS
          klcj(:, irestj+1:knbj  ) = kjmax-1
       ENDIF
       klcj(:,1:irestj) = kjmax
-      IF( MINVAL(klcj) < 3*khls ) THEN
+      IF( MINVAL(klcj) < 3*khls .AND. knbj > 1 ) THEN   ! if we do MPI communications along j (knbj > 1)
          WRITE(ctmp1,*) '   mpp_basesplit: minimum value of jpj must be >= ', 3*khls
          WRITE(ctmp2,*) '   We have ', MINVAL(klcj)
          CALL ctl_stop( 'STOP', ctmp1, ctmp2 )
@@ -775,13 +775,26 @@ CONTAINS
             ENDIF
          ENDIF
       END DO
+      
       IF( inbimax == 0 ) THEN
-         WRITE(ctmp1,'(a,i2,a,i2)') '   mpp_ini bestpartition: Ni0glo (', Ni0glo, ') is too small to be used with nn_hls = ', nn_hls
-         CALL ctl_stop( 'STOP', ctmp1 )
+         ! The domain is too small to cut it along the i direction. ==> force jpni = 1.
+         ! Note: halos larger than the inner domain along i: lbc_lnk OK if there is no MPI communications along i direction 
+         WRITE(ctmp1,'(a,i2,a,i2)')   &
+            &                  '   mpp_ini bestpartition: Ni0glo (',Ni0glo,') is too small to cut the domain with nn_hls = ', nn_hls
+         CALL ctl_warn( ctmp1, '                          We force jpni = 1 (no domain decomposition along i)' )
+         inbimax = 1                          ! only 1 case possible:
+         inbi0(inbimax) = 1                   !    only 1 domain along i
+         iszi0(inbimax) = Ni0glo + 2*nn_hls   !    total domain size along i when there is no domain decomposition
       ENDIF
       IF( inbjmax == 0 ) THEN
-         WRITE(ctmp1,'(a,i2,a,i2)') '   mpp_ini bestpartition: Nj0glo (', Nj0glo, ') is too small to be used with nn_hls = ', nn_hls
-         CALL ctl_stop( 'STOP', ctmp1 )
+         ! The domain is too small to cut it along the j direction. ==> force jpnj = 1.
+         ! Note: halos larger than the inner domain along j: lbc_lnk OK if there is no MPI communications along j direction 
+         WRITE(ctmp1,'(a,i2,a,i2)')   &
+            &                  '   mpp_ini bestpartition: Nj0glo (',Nj0glo,') is too small to cut the domain with nn_hls = ', nn_hls
+         CALL ctl_warn( ctmp1, '                          We force jpnj = 1 (no domain decomposition along j)' )
+         inbjmax = 1                          ! only 1 case possible:
+         inbj0(inbjmax) = 1                   !    only 1 domain along j
+         iszj0(inbjmax) = Nj0glo + 2*nn_hls   !    total domain size along j when there is no domain decomposition 
       ENDIF
 
       ! combine these 2 lists to get all possible knbi*knbj <  inbijmax