static int btrfs_load_block_group_dup(struct btrfs_block_group *bg,
                                      struct btrfs_chunk_map *map,
                                      struct zone_info *zone_info,
-                                     unsigned long *active)
+                                     unsigned long *active,
+                                     u64 last_alloc)
 {
        struct btrfs_fs_info *fs_info = bg->fs_info;
 
                          zone_info[1].physical);
                return -EIO;
        }
+
+       if (zone_info[0].alloc_offset == WP_CONVENTIONAL)
+               zone_info[0].alloc_offset = last_alloc;
+
+       if (zone_info[1].alloc_offset == WP_CONVENTIONAL)
+               zone_info[1].alloc_offset = last_alloc;
+
        if (zone_info[0].alloc_offset != zone_info[1].alloc_offset) {
                btrfs_err(bg->fs_info,
                          "zoned: write pointer offset mismatch of zones in DUP profile");
 static int btrfs_load_block_group_raid1(struct btrfs_block_group *bg,
                                        struct btrfs_chunk_map *map,
                                        struct zone_info *zone_info,
-                                       unsigned long *active)
+                                       unsigned long *active,
+                                       u64 last_alloc)
 {
        struct btrfs_fs_info *fs_info = bg->fs_info;
        int i;
        bg->zone_capacity = min_not_zero(zone_info[0].capacity, zone_info[1].capacity);
 
        for (i = 0; i < map->num_stripes; i++) {
-               if (zone_info[i].alloc_offset == WP_MISSING_DEV ||
-                   zone_info[i].alloc_offset == WP_CONVENTIONAL)
+               if (zone_info[i].alloc_offset == WP_MISSING_DEV)
                        continue;
 
+               if (zone_info[i].alloc_offset == WP_CONVENTIONAL)
+                       zone_info[i].alloc_offset = last_alloc;
+
                if ((zone_info[0].alloc_offset != zone_info[i].alloc_offset) &&
                    !btrfs_test_opt(fs_info, DEGRADED)) {
                        btrfs_err(fs_info,
 static int btrfs_load_block_group_raid0(struct btrfs_block_group *bg,
                                        struct btrfs_chunk_map *map,
                                        struct zone_info *zone_info,
-                                       unsigned long *active)
+                                       unsigned long *active,
+                                       u64 last_alloc)
 {
        struct btrfs_fs_info *fs_info = bg->fs_info;
 
        }
 
        for (int i = 0; i < map->num_stripes; i++) {
-               if (zone_info[i].alloc_offset == WP_MISSING_DEV ||
-                   zone_info[i].alloc_offset == WP_CONVENTIONAL)
+               if (zone_info[i].alloc_offset == WP_MISSING_DEV)
                        continue;
 
+               if (zone_info[i].alloc_offset == WP_CONVENTIONAL) {
+                       u64 stripe_nr, full_stripe_nr;
+                       u64 stripe_offset;
+                       int stripe_index;
+
+                       stripe_nr = div64_u64(last_alloc, map->stripe_size);
+                       stripe_offset = stripe_nr * map->stripe_size;
+                       full_stripe_nr = div_u64(stripe_nr, map->num_stripes);
+                       div_u64_rem(stripe_nr, map->num_stripes, &stripe_index);
+
+                       zone_info[i].alloc_offset =
+                               full_stripe_nr * map->stripe_size;
+
+                       if (stripe_index > i)
+                               zone_info[i].alloc_offset += map->stripe_size;
+                       else if (stripe_index == i)
+                               zone_info[i].alloc_offset +=
+                                       (last_alloc - stripe_offset);
+               }
+
                if (test_bit(0, active) != test_bit(i, active)) {
                        if (!btrfs_zone_activate(bg))
                                return -EIO;
 static int btrfs_load_block_group_raid10(struct btrfs_block_group *bg,
                                         struct btrfs_chunk_map *map,
                                         struct zone_info *zone_info,
-                                        unsigned long *active)
+                                        unsigned long *active,
+                                        u64 last_alloc)
 {
        struct btrfs_fs_info *fs_info = bg->fs_info;
 
        }
 
        for (int i = 0; i < map->num_stripes; i++) {
-               if (zone_info[i].alloc_offset == WP_MISSING_DEV ||
-                   zone_info[i].alloc_offset == WP_CONVENTIONAL)
+               if (zone_info[i].alloc_offset == WP_MISSING_DEV)
                        continue;
 
                if (test_bit(0, active) != test_bit(i, active)) {
                                set_bit(BLOCK_GROUP_FLAG_ZONE_IS_ACTIVE, &bg->runtime_flags);
                }
 
+               if (zone_info[i].alloc_offset == WP_CONVENTIONAL) {
+                       u64 stripe_nr, full_stripe_nr;
+                       u64 stripe_offset;
+                       int stripe_index;
+
+                       stripe_nr = div64_u64(last_alloc, map->stripe_size);
+                       stripe_offset = stripe_nr * map->stripe_size;
+                       full_stripe_nr = div_u64(stripe_nr,
+                                        map->num_stripes / map->sub_stripes);
+                       div_u64_rem(stripe_nr,
+                                   (map->num_stripes / map->sub_stripes),
+                                   &stripe_index);
+
+                       zone_info[i].alloc_offset =
+                               full_stripe_nr * map->stripe_size;
+
+                       if (stripe_index > (i / map->sub_stripes))
+                               zone_info[i].alloc_offset += map->stripe_size;
+                       else if (stripe_index == (i / map->sub_stripes))
+                               zone_info[i].alloc_offset +=
+                                       (last_alloc - stripe_offset);
+               }
+
                if ((i % map->sub_stripes) == 0) {
                        bg->zone_capacity += zone_info[i].capacity;
                        bg->alloc_offset += zone_info[i].alloc_offset;
                ret = btrfs_load_block_group_single(cache, &zone_info[0], active);
                break;
        case BTRFS_BLOCK_GROUP_DUP:
-               ret = btrfs_load_block_group_dup(cache, map, zone_info, active);
+               ret = btrfs_load_block_group_dup(cache, map, zone_info, active,
+                                                last_alloc);
                break;
        case BTRFS_BLOCK_GROUP_RAID1:
        case BTRFS_BLOCK_GROUP_RAID1C3:
        case BTRFS_BLOCK_GROUP_RAID1C4:
-               ret = btrfs_load_block_group_raid1(cache, map, zone_info, active);
+               ret = btrfs_load_block_group_raid1(cache, map, zone_info,
+                                                  active, last_alloc);
                break;
        case BTRFS_BLOCK_GROUP_RAID0:
-               ret = btrfs_load_block_group_raid0(cache, map, zone_info, active);
+               ret = btrfs_load_block_group_raid0(cache, map, zone_info,
+                                                  active, last_alloc);
                break;
        case BTRFS_BLOCK_GROUP_RAID10:
-               ret = btrfs_load_block_group_raid10(cache, map, zone_info, active);
+               ret = btrfs_load_block_group_raid10(cache, map, zone_info,
+                                                   active, last_alloc);
                break;
        case BTRFS_BLOCK_GROUP_RAID5:
        case BTRFS_BLOCK_GROUP_RAID6: