Re: [PATCH -next 2/3] md/raid10: convert resync_lock to use seqlock

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

在 2022/09/02 17:42, Guoqing Jiang 写道:
Hi,

On 8/29/22 9:15 PM, Yu Kuai wrote:
+static bool wait_barrier_nolock(struct r10conf *conf)
+{
+    unsigned int seq = raw_read_seqcount(&conf->resync_lock.seqcount);
+
+    if (seq & 1)
+        return false;
+
+    if (READ_ONCE(conf->barrier))
+        return false;
+
+    atomic_inc(&conf->nr_pending);
+    if (!read_seqcount_retry(&conf->resync_lock.seqcount, seq))

I think 'seq' is usually get from read_seqcount_begin.

read_seqcount_begin will loop untill "req & 1" failed, I'm afraid this
will cause high cpu usage in come cases.

What I try to do here is just try once, and fall back to hold lock and
wait if failed.

What do you think?

Thanks,
Kuai

+        return true;
+
+    atomic_dec(&conf->nr_pending);
+    return false;
+

Thanks,
Guoqing
.





[Index of Archives]     [Linux RAID Wiki]     [ATA RAID]     [Linux SCSI Target Infrastructure]     [Linux Block]     [Linux IDE]     [Linux SCSI]     [Linux Hams]     [Device Mapper]     [Device Mapper Cryptographics]     [Kernel]     [Linux Admin]     [Linux Net]     [GFS]     [RPM]     [git]     [Yosemite Forum]


  Powered by Linux