1bf215546Sopenharmony_ci#
2bf215546Sopenharmony_ci# Copyright (C) 2019 Igalia S.L.
3bf215546Sopenharmony_ci#
4bf215546Sopenharmony_ci# Permission is hereby granted, free of charge, to any person obtaining a
5bf215546Sopenharmony_ci# copy of this software and associated documentation files (the "Software"),
6bf215546Sopenharmony_ci# to deal in the Software without restriction, including without limitation
7bf215546Sopenharmony_ci# the rights to use, copy, modify, merge, publish, distribute, sublicense,
8bf215546Sopenharmony_ci# and/or sell copies of the Software, and to permit persons to whom the
9bf215546Sopenharmony_ci# Software is furnished to do so, subject to the following conditions:
10bf215546Sopenharmony_ci#
11bf215546Sopenharmony_ci# The above copyright notice and this permission notice (including the next
12bf215546Sopenharmony_ci# paragraph) shall be included in all copies or substantial portions of the
13bf215546Sopenharmony_ci# Software.
14bf215546Sopenharmony_ci#
15bf215546Sopenharmony_ci# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16bf215546Sopenharmony_ci# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17bf215546Sopenharmony_ci# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18bf215546Sopenharmony_ci# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19bf215546Sopenharmony_ci# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20bf215546Sopenharmony_ci# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21bf215546Sopenharmony_ci# IN THE SOFTWARE.
22bf215546Sopenharmony_ci
23bf215546Sopenharmony_ciimport argparse
24bf215546Sopenharmony_ciimport sys
25bf215546Sopenharmony_ci
26bf215546Sopenharmony_ciimul_lowering = [
27bf215546Sopenharmony_ci	(('imul', 'a@32', 'b@32'), ('imadsh_mix16', 'b', 'a', ('imadsh_mix16', 'a', 'b', ('umul_low', 'a', 'b')))),
28bf215546Sopenharmony_ci        # We want to run the imad24 rule late so that it doesn't fight
29bf215546Sopenharmony_ci        # with constant folding the (imul24, a, b).  Since this pass is
30bf215546Sopenharmony_ci        # run late, and this is kinda imul related, this seems like a
31bf215546Sopenharmony_ci        # good place for it:
32bf215546Sopenharmony_ci        (('iadd', ('imul24', 'a', 'b'), 'c'), ('imad24_ir3', 'a', 'b', 'c')),
33bf215546Sopenharmony_ci]
34bf215546Sopenharmony_ci
35bf215546Sopenharmony_ci
36bf215546Sopenharmony_cidef main():
37bf215546Sopenharmony_ci    parser = argparse.ArgumentParser()
38bf215546Sopenharmony_ci    parser.add_argument('-p', '--import-path', required=True)
39bf215546Sopenharmony_ci    args = parser.parse_args()
40bf215546Sopenharmony_ci    sys.path.insert(0, args.import_path)
41bf215546Sopenharmony_ci    run()
42bf215546Sopenharmony_ci
43bf215546Sopenharmony_ci
44bf215546Sopenharmony_cidef run():
45bf215546Sopenharmony_ci    import nir_algebraic  # pylint: disable=import-error
46bf215546Sopenharmony_ci
47bf215546Sopenharmony_ci    print('#include "ir3_nir.h"')
48bf215546Sopenharmony_ci    print(nir_algebraic.AlgebraicPass("ir3_nir_lower_imul",
49bf215546Sopenharmony_ci                                      imul_lowering).render())
50bf215546Sopenharmony_ci
51bf215546Sopenharmony_ci
52bf215546Sopenharmony_ciif __name__ == '__main__':
53bf215546Sopenharmony_ci    main()
54