Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

kconfig: remove 'e1' and 'e2' macros from expression deduplication

I do not think the macros 'e1' and 'e2' are readable.

The statement:

e1 = expr_alloc_symbol(...);

affects the caller's variable, but this is not sufficiently clear from the code.

Remove the macros. No functional change intended.

Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>

+42 -52
+42 -52
scripts/kconfig/expr.c
··· 135 135 136 136 static int trans_count; 137 137 138 - #define e1 (*ep1) 139 - #define e2 (*ep2) 140 - 141 138 /* 142 139 * expr_eliminate_eq() helper. 143 140 * ··· 147 150 { 148 151 /* Recurse down to leaves */ 149 152 150 - if (e1->type == type) { 151 - __expr_eliminate_eq(type, &e1->left.expr, &e2); 152 - __expr_eliminate_eq(type, &e1->right.expr, &e2); 153 + if ((*ep1)->type == type) { 154 + __expr_eliminate_eq(type, &(*ep1)->left.expr, ep2); 155 + __expr_eliminate_eq(type, &(*ep1)->right.expr, ep2); 153 156 return; 154 157 } 155 - if (e2->type == type) { 156 - __expr_eliminate_eq(type, &e1, &e2->left.expr); 157 - __expr_eliminate_eq(type, &e1, &e2->right.expr); 158 + if ((*ep2)->type == type) { 159 + __expr_eliminate_eq(type, ep1, &(*ep2)->left.expr); 160 + __expr_eliminate_eq(type, ep1, &(*ep2)->right.expr); 158 161 return; 159 162 } 160 163 161 - /* e1 and e2 are leaves. Compare them. */ 164 + /* *ep1 and *ep2 are leaves. Compare them. */ 162 165 163 - if (e1->type == E_SYMBOL && e2->type == E_SYMBOL && 164 - e1->left.sym == e2->left.sym && 165 - (e1->left.sym == &symbol_yes || e1->left.sym == &symbol_no)) 166 + if ((*ep1)->type == E_SYMBOL && (*ep2)->type == E_SYMBOL && 167 + (*ep1)->left.sym == (*ep2)->left.sym && 168 + ((*ep1)->left.sym == &symbol_yes || (*ep1)->left.sym == &symbol_no)) 166 169 return; 167 - if (!expr_eq(e1, e2)) 170 + if (!expr_eq(*ep1, *ep2)) 168 171 return; 169 172 170 - /* e1 and e2 are equal leaves. Prepare them for elimination. */ 173 + /* *ep1 and *ep2 are equal leaves. Prepare them for elimination. */ 171 174 172 175 trans_count++; 173 - expr_free(e1); expr_free(e2); 176 + expr_free(*ep1); expr_free(*ep2); 174 177 switch (type) { 175 178 case E_OR: 176 - e1 = expr_alloc_symbol(&symbol_no); 177 - e2 = expr_alloc_symbol(&symbol_no); 179 + *ep1 = expr_alloc_symbol(&symbol_no); 180 + *ep2 = expr_alloc_symbol(&symbol_no); 178 181 break; 179 182 case E_AND: 180 - e1 = expr_alloc_symbol(&symbol_yes); 181 - e2 = expr_alloc_symbol(&symbol_yes); 183 + *ep1 = expr_alloc_symbol(&symbol_yes); 184 + *ep2 = expr_alloc_symbol(&symbol_yes); 182 185 break; 183 186 default: 184 187 ; ··· 216 219 */ 217 220 void expr_eliminate_eq(struct expr **ep1, struct expr **ep2) 218 221 { 219 - if (!e1 || !e2) 222 + if (!*ep1 || !*ep2) 220 223 return; 221 - switch (e1->type) { 224 + switch ((*ep1)->type) { 222 225 case E_OR: 223 226 case E_AND: 224 - __expr_eliminate_eq(e1->type, ep1, ep2); 227 + __expr_eliminate_eq((*ep1)->type, ep1, ep2); 225 228 default: 226 229 ; 227 230 } 228 - if (e1->type != e2->type) switch (e2->type) { 231 + if ((*ep1)->type != (*ep2)->type) switch ((*ep2)->type) { 229 232 case E_OR: 230 233 case E_AND: 231 - __expr_eliminate_eq(e2->type, ep1, ep2); 234 + __expr_eliminate_eq((*ep2)->type, ep1, ep2); 232 235 default: 233 236 ; 234 237 } 235 - e1 = expr_eliminate_yn(e1); 236 - e2 = expr_eliminate_yn(e2); 238 + *ep1 = expr_eliminate_yn(*ep1); 239 + *ep2 = expr_eliminate_yn(*ep2); 237 240 } 238 - 239 - #undef e1 240 - #undef e2 241 241 242 242 /* 243 243 * Returns true if 'e1' and 'e2' are equal, after minor simplification. Two ··· 558 564 */ 559 565 static void expr_eliminate_dups1(enum expr_type type, struct expr **ep1, struct expr **ep2) 560 566 { 561 - #define e1 (*ep1) 562 - #define e2 (*ep2) 563 567 struct expr *tmp; 564 568 565 569 /* Recurse down to leaves */ 566 570 567 - if (e1->type == type) { 568 - expr_eliminate_dups1(type, &e1->left.expr, &e2); 569 - expr_eliminate_dups1(type, &e1->right.expr, &e2); 571 + if ((*ep1)->type == type) { 572 + expr_eliminate_dups1(type, &(*ep1)->left.expr, ep2); 573 + expr_eliminate_dups1(type, &(*ep1)->right.expr, ep2); 570 574 return; 571 575 } 572 - if (e2->type == type) { 573 - expr_eliminate_dups1(type, &e1, &e2->left.expr); 574 - expr_eliminate_dups1(type, &e1, &e2->right.expr); 576 + if ((*ep2)->type == type) { 577 + expr_eliminate_dups1(type, ep1, &(*ep2)->left.expr); 578 + expr_eliminate_dups1(type, ep1, &(*ep2)->right.expr); 575 579 return; 576 580 } 577 581 578 - /* e1 and e2 are leaves. Compare and process them. */ 582 + /* *ep1 and *ep2 are leaves. Compare and process them. */ 579 583 580 - if (e1 == e2) 584 + if (*ep1 == *ep2) 581 585 return; 582 586 583 - switch (e1->type) { 587 + switch ((*ep1)->type) { 584 588 case E_OR: case E_AND: 585 - expr_eliminate_dups1(e1->type, &e1, &e1); 589 + expr_eliminate_dups1((*ep1)->type, ep1, ep1); 586 590 default: 587 591 ; 588 592 } 589 593 590 594 switch (type) { 591 595 case E_OR: 592 - tmp = expr_join_or(e1, e2); 596 + tmp = expr_join_or(*ep1, *ep2); 593 597 if (tmp) { 594 - expr_free(e1); expr_free(e2); 595 - e1 = expr_alloc_symbol(&symbol_no); 596 - e2 = tmp; 598 + expr_free(*ep1); expr_free(*ep2); 599 + *ep1 = expr_alloc_symbol(&symbol_no); 600 + *ep2 = tmp; 597 601 trans_count++; 598 602 } 599 603 break; 600 604 case E_AND: 601 - tmp = expr_join_and(e1, e2); 605 + tmp = expr_join_and(*ep1, *ep2); 602 606 if (tmp) { 603 - expr_free(e1); expr_free(e2); 604 - e1 = expr_alloc_symbol(&symbol_yes); 605 - e2 = tmp; 607 + expr_free(*ep1); expr_free(*ep2); 608 + *ep1 = expr_alloc_symbol(&symbol_yes); 609 + *ep2 = tmp; 606 610 trans_count++; 607 611 } 608 612 break; 609 613 default: 610 614 ; 611 615 } 612 - #undef e1 613 - #undef e2 614 616 } 615 617 616 618 /*