/* Lowering routines for all things related to BOOL values. Copyright (C) 2025 Jose E. Marchesi. Written by Jose E. Marchesi. GCC is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. GCC is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GCC; see the file COPYING3. If not see . */ #define INCLUDE_MEMORY #include "config.h" #include "system.h" #include "coretypes.h" #include "tree.h" #include "fold-const.h" #include "diagnostic.h" #include "langhooks.h" #include "tm.h" #include "function.h" #include "cgraph.h" #include "toplev.h" #include "varasm.h" #include "predict.h" #include "stor-layout.h" #include "tree-iterator.h" #include "stringpool.h" #include "print-tree.h" #include "gimplify.h" #include "dumpfile.h" #include "convert.h" #include "a68.h" /* Return a tree with the yielind of SKIP of a BOOL mode. */ tree a68_get_bool_skip_tree (void) { return build_int_cst (a68_bool_type, 0); } /* The absolute value of a BOOL is a non-zero INT for TRUE and zero for FALSE. */ tree a68_bool_abs (tree val) { return fold_convert (a68_int_type, val); } /* Given two boolean values, build an expression that calculates whether A = B. */ tree a68_bool_eq (tree a, tree b, location_t loc) { return fold_build2_loc (loc, EQ_EXPR, boolean_type_node, a, b); } /* Given two boolean values, build an expression that calculates whether A /= B. */ tree a68_bool_ne (tree a, tree b, location_t loc) { return fold_build2_loc (loc, NE_EXPR, boolean_type_node, a, b); }