]> git.ipfire.org Git - thirdparty/bind9.git/commitdiff
Fix dns_qpmulti_memusage() on empty dns_qpmulti_t instance
authorOndřej Surý <ondrej@isc.org>
Tue, 16 Sep 2025 12:11:08 +0000 (14:11 +0200)
committerOndřej Surý <ondrej@isc.org>
Tue, 16 Sep 2025 14:30:15 +0000 (16:30 +0200)
The dns_qpmulti_memusage() causes assertion failure when called on
freshly created qpmulti instance because the qp->usage hasn't been
allocated yet.

lib/dns/qp.c
tests/dns/qpmulti_test.c

index aa717c1301278a7d2b2a16d6bf5d8b4e7eb63240..d27726d74f9ada81b913539779613b5a46024d3b 100644 (file)
@@ -1124,7 +1124,7 @@ dns_qpmulti_memusage(dns_qpmulti_t *multi) {
 
        dns_qp_memusage_t memusage = dns_qp_memusage(qp);
 
-       if (qp->transaction_mode == QP_UPDATE) {
+       if (qp->transaction_mode == QP_UPDATE && qp->usage != NULL) {
                memusage.bytes -= qp->usage[qp->bump].capacity;
                memusage.bytes += qp->usage[qp->bump].used *
                                  sizeof(dns_qpnode_t);
index 9ecc68bb6c11fd1bf471ff8cee619109d0236900..6231b4f44204f2abf74e6604e2084bd7ea8632ae 100644 (file)
@@ -378,8 +378,22 @@ ISC_RUN_TEST_IMPL(qpmulti) {
        isc_loopmgr_destroy();
 }
 
+ISC_RUN_TEST_IMPL(qpmulti_memusage) {
+       dns_qpmulti_t *qpm = NULL;
+       dns_qp_memusage_t mu;
+
+       dns_qpmulti_create(isc_g_mctx, &test_methods, NULL, &qpm);
+
+       mu = dns_qpmulti_memusage(qpm);
+       assert_int_equal(mu.leaves, 0);
+       assert_int_equal(mu.used, 0);
+
+       dns_qpmulti_destroy(&qpm);
+}
+
 ISC_TEST_LIST_START
 ISC_TEST_ENTRY(qpmulti)
+ISC_TEST_ENTRY(qpmulti_memusage)
 ISC_TEST_LIST_END
 
 ISC_TEST_MAIN