17ec681f3Smrg/*
27ec681f3Smrg * Copyright © 2020 Valve Corporation
37ec681f3Smrg *
47ec681f3Smrg * Permission is hereby granted, free of charge, to any person obtaining a
57ec681f3Smrg * copy of this software and associated documentation files (the "Software"),
67ec681f3Smrg * to deal in the Software without restriction, including without limitation
77ec681f3Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense,
87ec681f3Smrg * and/or sell copies of the Software, and to permit persons to whom the
97ec681f3Smrg * Software is furnished to do so, subject to the following conditions:
107ec681f3Smrg *
117ec681f3Smrg * The above copyright notice and this permission notice (including the next
127ec681f3Smrg * paragraph) shall be included in all copies or substantial portions of the
137ec681f3Smrg * Software.
147ec681f3Smrg *
157ec681f3Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
167ec681f3Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
177ec681f3Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
187ec681f3Smrg * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
197ec681f3Smrg * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
207ec681f3Smrg * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
217ec681f3Smrg * IN THE SOFTWARE.
227ec681f3Smrg *
237ec681f3Smrg */
247ec681f3Smrg#include "helpers.h"
257ec681f3Smrg#include <stdio.h>
267ec681f3Smrg
277ec681f3Smrgusing namespace aco;
287ec681f3Smrg
297ec681f3SmrgBEGIN_TEST_TODO(todo)
307ec681f3Smrg   //!test!
317ec681f3Smrg   fprintf(output, "woops!\n");
327ec681f3SmrgEND_TEST
337ec681f3Smrg
347ec681f3SmrgBEGIN_TEST_FAIL(expect_fail)
357ec681f3Smrg   //!test!
367ec681f3Smrg   fprintf(output, "woops!\n");
377ec681f3SmrgEND_TEST
387ec681f3Smrg
397ec681f3SmrgBEGIN_TEST(simple.1)
407ec681f3Smrg   //! s_buffer_load_dwordx2 @s64(a)
417ec681f3Smrg   fprintf(output, "s_buffer_load_dwordx2 s[6:7]\n");
427ec681f3Smrg   //! s_add_u32 s#b0, s#a, 1
437ec681f3Smrg   //! s_addc_u32 s#b1, s#a1, 0
447ec681f3Smrg   //; success = int(b0) == 8
457ec681f3Smrg   fprintf(output, "s_add_u32 s8, s6, 1\n");
467ec681f3Smrg   fprintf(output, "s_addc_u32 s9, s7, 0\n");
477ec681f3Smrg   //! s_buffer_store_dwordx2 @s64(b)
487ec681f3Smrg   fprintf(output, "s_buffer_store_dwordx2 s[8:9]\n");
497ec681f3SmrgEND_TEST
507ec681f3Smrg
517ec681f3SmrgBEGIN_TEST(simple.2)
527ec681f3Smrg   //~gfx[67]! test gfx67
537ec681f3Smrg   //~gfx8! test gfx8
547ec681f3Smrg   //~gfx9! test gfx9
557ec681f3Smrg   //! test all
567ec681f3Smrg   for (int cls = GFX6; cls <= GFX7; cls++) {
577ec681f3Smrg      if (!set_variant((enum chip_class)cls))
587ec681f3Smrg         continue;
597ec681f3Smrg      fprintf(output, "test gfx67\n");
607ec681f3Smrg      fprintf(output, "test all\n");
617ec681f3Smrg   }
627ec681f3Smrg
637ec681f3Smrg   if (set_variant("gfx8")) {
647ec681f3Smrg      fprintf(output, "test gfx8\n");
657ec681f3Smrg      fprintf(output, "test all\n");
667ec681f3Smrg   }
677ec681f3Smrg
687ec681f3Smrg   if (set_variant("gfx9")) {
697ec681f3Smrg      fprintf(output, "test gfx9\n");
707ec681f3Smrg      fprintf(output, "test all\n");
717ec681f3Smrg   }
727ec681f3SmrgEND_TEST
737ec681f3Smrg
747ec681f3SmrgBEGIN_TEST(simple.3)
757ec681f3Smrg   //; funcs['test'] = lambda a: a
767ec681f3Smrg   //! @test(s_buffer_load_dwordx2) @s64(a)
777ec681f3Smrg   fprintf(output, "s_buffer_load_dwordx2 s[6:7]\n");
787ec681f3SmrgEND_TEST
79