162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (c) 2021, The Linux Foundation. All rights reserved. 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#include <linux/linkage.h> 762306a36Sopenharmony_ci 862306a36Sopenharmony_ciSYM_FUNC_START(__hexagon_udivsi3) 962306a36Sopenharmony_ci { 1062306a36Sopenharmony_ci r2 = cl0(r0) 1162306a36Sopenharmony_ci r3 = cl0(r1) 1262306a36Sopenharmony_ci r5:4 = combine(#1,#0) 1362306a36Sopenharmony_ci p0 = cmp.gtu(r1,r0) 1462306a36Sopenharmony_ci } 1562306a36Sopenharmony_ci { 1662306a36Sopenharmony_ci r6 = sub(r3,r2) 1762306a36Sopenharmony_ci r4 = r1 1862306a36Sopenharmony_ci r1:0 = combine(r0,r4) 1962306a36Sopenharmony_ci if (p0) jumpr r31 2062306a36Sopenharmony_ci } 2162306a36Sopenharmony_ci { 2262306a36Sopenharmony_ci r3:2 = vlslw(r5:4,r6) 2362306a36Sopenharmony_ci loop0(1f,r6) 2462306a36Sopenharmony_ci } 2562306a36Sopenharmony_ci .falign 2662306a36Sopenharmony_ci1: 2762306a36Sopenharmony_ci { 2862306a36Sopenharmony_ci p0 = cmp.gtu(r2,r1) 2962306a36Sopenharmony_ci if (!p0.new) r1 = sub(r1,r2) 3062306a36Sopenharmony_ci if (!p0.new) r0 = add(r0,r3) 3162306a36Sopenharmony_ci r3:2 = vlsrw(r3:2,#1) 3262306a36Sopenharmony_ci }:endloop0 3362306a36Sopenharmony_ci { 3462306a36Sopenharmony_ci p0 = cmp.gtu(r2,r1) 3562306a36Sopenharmony_ci if (!p0.new) r0 = add(r0,r3) 3662306a36Sopenharmony_ci jumpr r31 3762306a36Sopenharmony_ci } 3862306a36Sopenharmony_ciSYM_FUNC_END(__hexagon_udivsi3) 39