annotate libgcc/udivmodhi4.c @ 144:8f4e72ab4e11

fix segmentation fault caused by nothing next cur_op to end
author Takahiro SHIMIZU <anatofuz@cr.ie.u-ryukyu.ac.jp>
date Sun, 23 Dec 2018 21:23:56 +0900
parents 84e7813d76e9
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
131
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
1 /* Copyright (C) 2000-2018 Free Software Foundation, Inc.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
2
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
3 This file is part of GCC.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
4
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
5 GCC is free software; you can redistribute it and/or modify it under
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
6 the terms of the GNU General Public License as published by the Free
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
7 Software Foundation; either version 3, or (at your option) any later
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
8 version.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
9
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
10 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
11 WARRANTY; without even the implied warranty of MERCHANTABILITY or
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
12 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
13 for more details.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
14
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
15 Under Section 7 of GPL version 3, you are granted additional
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
16 permissions described in the GCC Runtime Library Exception, version
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
17 3.1, as published by the Free Software Foundation.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
18
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
19 You should have received a copy of the GNU General Public License and
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
20 a copy of the GCC Runtime Library Exception along with this program;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
21 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
22 <http://www.gnu.org/licenses/>. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
23
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
24 unsigned short
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
25 __udivmodhi4(unsigned short num, unsigned short den, int modwanted)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
26 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
27 unsigned short bit = 1;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
28 unsigned short res = 0;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
29
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
30 while (den < num && bit && !(den & (1L<<31)))
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
31 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
32 den <<=1;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
33 bit <<=1;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
34 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
35 while (bit)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
36 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
37 if (num >= den)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
38 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
39 num -= den;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
40 res |= bit;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
41 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
42 bit >>=1;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
43 den >>=1;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
44 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
45 if (modwanted) return num;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
46 return res;
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
47 }