Alexander Motin
928eccc5bc
DDT: Reduce global DDT lock scope during writes
...
Before this change DDT lock was taken 4 times per written block,
and as effectively a pool-wide lock it can be highly congested.
This change introduces a new per-entry dde_io_lock, protecting some
fields during I/O ready and done stages, so that we don't need the
global lock there.
According to my write tests on 64-thread system with 4KB blocks this
significantly reduce the global lock contention, reducing CPU usage
from 100% to expected ~80%, and increasing write throughput by 10%.
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov >
Reviewed-by: Rob Norris <robn@despairlabs.com >
Signed-off-by: Alexander Motin <alexander.motin@TrueNAS.com >
Closes #17960
2025-12-01 10:44:10 -08:00
..
2025-08-07 11:41:25 -07:00
2025-03-13 17:56:27 -07:00
2025-11-10 14:23:39 -08:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-10-29 11:17:51 -07:00
2025-10-29 11:17:51 -07:00
2025-03-13 17:56:27 -07:00
2025-11-10 16:16:22 -08:00
2025-08-07 11:41:42 -07:00
2025-08-08 16:43:26 -07:00
2025-03-13 17:56:27 -07:00
2025-10-30 16:28:28 -07:00
2025-10-30 16:28:28 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-12-01 10:44:10 -08:00
2025-08-06 10:36:07 -07:00
2025-08-07 11:41:42 -07:00
2025-08-07 11:41:42 -07:00
2025-08-21 06:05:29 -07:00
2025-08-07 11:41:42 -07:00
2025-10-29 11:17:51 -07:00
2025-08-07 11:41:42 -07:00
2025-08-06 10:36:07 -07:00
2025-08-07 11:40:59 -07:00
2025-09-08 10:03:01 -07:00
2025-11-10 16:16:22 -08:00
2025-08-07 11:41:42 -07:00
2025-11-04 13:12:17 -08:00
2025-08-07 11:41:42 -07:00
2025-08-07 11:41:42 -07:00
2025-08-07 11:41:37 -07:00
2025-08-13 15:56:25 -04:00
2025-08-07 11:40:59 -07:00
2025-08-07 11:41:42 -07:00
2025-08-07 11:40:59 -07:00
2025-08-07 11:41:37 -07:00
2025-08-07 11:40:59 -07:00
2025-08-07 11:41:42 -07:00
2025-05-28 10:28:59 -07:00
2025-08-07 11:40:59 -07:00
2025-03-13 17:56:27 -07:00
2025-08-07 11:40:59 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:46 -07:00
2025-03-13 17:56:46 -07:00
2025-03-13 17:56:27 -07:00
2025-10-29 11:17:51 -07:00
2025-11-10 14:23:39 -08:00
2025-08-12 13:36:03 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-09-29 16:38:52 -07:00
2025-05-02 15:32:18 -07:00
2025-08-07 11:41:37 -07:00
2025-08-07 11:41:25 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-10-29 11:17:51 -07:00
2025-11-10 14:23:39 -08:00
2025-08-06 10:36:07 -07:00
2025-10-29 11:17:51 -07:00
2025-03-13 17:56:27 -07:00
2025-11-10 14:23:39 -08:00
2025-08-07 11:40:59 -07:00
2025-11-10 14:23:39 -08:00
2025-10-29 11:17:51 -07:00
2025-08-07 11:40:59 -07:00
2018-06-06 09:35:59 -07:00
2018-06-06 09:35:59 -07:00
2025-05-28 10:27:46 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:57:31 -07:00
2025-09-10 15:25:03 -07:00
2025-09-10 11:13:55 -07:00
2025-10-29 11:17:51 -07:00
2025-10-29 11:17:51 -07:00
2025-08-07 11:41:42 -07:00
2025-11-10 14:23:39 -08:00
2025-10-30 16:29:48 -07:00
2025-08-06 10:36:07 -07:00
2025-05-02 15:32:18 -07:00
2025-09-08 10:03:01 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-05-28 16:50:22 -07:00
2025-11-07 09:55:03 -08:00
2025-11-10 14:23:39 -08:00
2025-11-10 14:23:39 -08:00
2025-05-02 15:32:18 -07:00
2025-11-10 14:23:39 -08:00
2025-11-11 10:42:17 -08:00
2025-03-13 17:56:27 -07:00
2025-11-10 14:26:15 -08:00
2025-08-07 11:41:25 -07:00
2025-05-27 20:04:37 -04:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-03-13 17:56:27 -07:00
2025-06-10 14:53:10 -07:00
2025-08-07 11:41:42 -07:00
2025-08-22 16:35:58 -07:00
2025-03-13 17:56:27 -07:00
2025-12-01 10:14:52 -08:00
2025-09-12 16:33:36 -07:00
2025-04-18 09:22:16 -04:00
2025-11-11 10:42:17 -08:00
2025-11-12 10:01:48 -08:00
2025-03-13 17:56:27 -07:00
2025-11-10 16:16:22 -08:00
2025-08-08 16:43:20 -07:00
2025-03-13 17:56:27 -07:00
2025-08-07 11:40:59 -07:00
2025-03-13 17:56:27 -07:00
2025-03-18 16:04:22 -07:00
2025-08-07 11:41:25 -07:00
2025-08-08 16:43:09 -07:00
2025-08-08 16:43:09 -07:00
2025-04-03 10:35:22 -07:00
2025-08-14 08:50:17 -07:00
2025-08-07 11:40:59 -07:00
2025-08-06 17:10:03 -07:00
2025-11-10 14:23:39 -08:00
2025-12-01 10:44:10 -08:00
2025-03-13 17:56:27 -07:00
2025-08-07 11:41:42 -07:00
2025-08-07 11:41:42 -07:00
2025-11-10 14:23:39 -08:00