libFIRM provides a graph-based intermediate representation (IR), which operates exclusively in SSA-form, starting at IR construction until assembler code emission. It offers many analyses and optimizations, provides extensive debug support and includes a backend framework. * analyses: dominance, loop tree, execution frequency, control dependencies, call graph, rapid type, def-use, alias analysis, class hierarchy analysis * optimizations: dead code elimination (happens implicitly), constant folding, local common subexpression elimination, arithmetic identities (happens on the fly), unreachable code elimination, global common subexpression elimination, code placement, strength reduction, scalar replacement, if-conversion, load/store optimization, control flow optimizations, reassociation, partial condition evaluation, tail recursion elimination, inlining, procedure cloning * enhanced debugging support: extensive checkers, breakpoints on node creation, entity creation, graph dumping * lowering of intrinsics, double word arithmetics, bitfields * generic backend features: * novel SSA based register allocator * several SSA copy coalescing and spilling algorithms * algorithms for instruction and basic block scheduling * working ia32 backend, unfinished backends for MIPS, ARM, PPC32 * handwritten recursive descent C89/C99 frontend available (lang/cparser)
OS | Architecture | Version |
---|---|---|
NetBSD 10.0 | aarch64 | libfirm-1.21.0.tgz |
NetBSD 10.0 | aarch64 | libfirm-1.21.0.tgz |
NetBSD 10.0 | aarch64eb | libfirm-1.21.0.tgz |
NetBSD 10.0 | aarch64eb | libfirm-1.21.0.tgz |
NetBSD 10.0 | alpha | libfirm-1.21.0.tgz |
NetBSD 10.0 | alpha | libfirm-1.21.0.tgz |
NetBSD 10.0 | earmv4 | libfirm-1.21.0.tgz |
NetBSD 10.0 | earmv4 | libfirm-1.21.0.tgz |
NetBSD 10.0 | earmv6hf | libfirm-1.21.0.tgz |
NetBSD 10.0 | earmv6hf | libfirm-1.21.0.tgz |
NetBSD 10.0 | earmv6hf | libfirm-1.21.0.tgz |
NetBSD 10.0 | earmv7hf | libfirm-1.21.0.tgz |
NetBSD 10.0 | earmv7hf | libfirm-1.21.0.tgz |
NetBSD 10.0 | earmv7hf | libfirm-1.21.0.tgz |
NetBSD 10.0 | i386 | libfirm-1.21.0.tgz |
NetBSD 10.0 | i386 | libfirm-1.21.0.tgz |
NetBSD 10.0 | m68k | libfirm-1.21.0.tgz |
NetBSD 10.0 | powerpc | libfirm-1.21.0.tgz |
NetBSD 10.0 | powerpc | libfirm-1.21.0.tgz |
NetBSD 10.0 | powerpc | libfirm-1.21.0.tgz |
NetBSD 10.0 | sh3el | libfirm-1.21.0.tgz |
NetBSD 10.0 | sh3el | libfirm-1.21.0.tgz |
NetBSD 10.0 | sparc64 | libfirm-1.21.0.tgz |
NetBSD 10.0 | sparc64 | libfirm-1.21.0.tgz |
NetBSD 10.0 | sparc | libfirm-1.21.0.tgz |
NetBSD 10.0 | sparc | libfirm-1.21.0.tgz |
NetBSD 10.0 | vax | libfirm-1.21.0.tgz |
NetBSD 10.0 | vax | libfirm-1.21.0.tgz |
NetBSD 10.0 | vax | libfirm-1.21.0.tgz |
NetBSD 10.0 | x86_64 | libfirm-1.21.0.tgz |
NetBSD 10.0 | x86_64 | libfirm-1.21.0.tgz |
NetBSD 9.0 | aarch64 | libfirm-1.21.0.tgz |
NetBSD 9.0 | aarch64 | libfirm-1.21.0.tgz |
NetBSD 9.0 | alpha | libfirm-1.21.0.tgz |
NetBSD 9.0 | alpha | libfirm-1.21.0.tgz |
NetBSD 9.0 | earmv4 | libfirm-1.21.0.tgz |
NetBSD 9.0 | earmv6hf | libfirm-1.21.0.tgz |
NetBSD 9.0 | earmv6hf | libfirm-1.21.0.tgz |
NetBSD 9.0 | earmv6hf | libfirm-1.21.0.tgz |
NetBSD 9.0 | earmv7hf | libfirm-1.21.0.tgz |
NetBSD 9.0 | earmv7hf | libfirm-1.21.0.tgz |
NetBSD 9.0 | earmv7hf | libfirm-1.21.0.tgz |
NetBSD 9.0 | i386 | libfirm-1.21.0.tgz |
NetBSD 9.0 | i386 | libfirm-1.21.0.tgz |
NetBSD 9.0 | powerpc | libfirm-1.21.0.tgz |
NetBSD 9.0 | powerpc | libfirm-1.21.0.tgz |
NetBSD 9.0 | powerpc | libfirm-1.21.0.tgz |
NetBSD 9.0 | sparc64 | libfirm-1.21.0.tgz |
NetBSD 9.0 | x86_64 | libfirm-1.21.0.tgz |
NetBSD 9.0 | x86_64 | libfirm-1.21.0.tgz |
NetBSD 9.3 | x86_64 | libfirm-1.21.0.tgz |
Binary packages can be installed with the high-level tool pkgin (which can be installed with pkg_add) or pkg_add(1) (installed by default). The NetBSD packages collection is also designed to permit easy installation from source.
The pkg_admin audit command locates any installed package which has been mentioned in security advisories as having vulnerabilities.
Please note the vulnerabilities database might not be fully accurate, and not every bug is exploitable with every configuration.
Problem reports, updates or suggestions for this package should be reported with send-pr.