/* * Test the LCBB instruction. * * SPDX-License-Identifier: GPL-2.0-or-later */ #include #include static inline __attribute__((__always_inline__)) void lcbb(long *r1, void *dxb2, int m3, int *cc) { asm("lcbb %[r1],%[dxb2],%[m3]\n" "ipm %[cc]" : [r1] "+r" (*r1), [cc] "=r" (*cc) : [dxb2] "R" (*(char *)dxb2), [m3] "i" (m3) : "cc"); *cc = (*cc >> 28) & 3; } static char buf[0x1000] __attribute__((aligned(0x1000))); static inline __attribute__((__always_inline__)) void test_lcbb(void *p, int m3, int exp_r1, int exp_cc) { long r1 = 0xfedcba9876543210; int cc; lcbb(&r1, p, m3, &cc); assert(r1 == (0xfedcba9800000000 | exp_r1)); assert(cc == exp_cc); } int main(void) { test_lcbb(&buf[0], 0, 16, 0); test_lcbb(&buf[63], 0, 1, 3); test_lcbb(&buf[0], 1, 16, 0); test_lcbb(&buf[127], 1, 1, 3); test_lcbb(&buf[0], 2, 16, 0); test_lcbb(&buf[255], 2, 1, 3); test_lcbb(&buf[0], 3, 16, 0); test_lcbb(&buf[511], 3, 1, 3); test_lcbb(&buf[0], 4, 16, 0); test_lcbb(&buf[1023], 4, 1, 3); test_lcbb(&buf[0], 5, 16, 0); test_lcbb(&buf[2047], 5, 1, 3); test_lcbb(&buf[0], 6, 16, 0); test_lcbb(&buf[4095], 6, 1, 3); return EXIT_SUCCESS; }