1*7304104dSAndroid Build Coastguard Worker /* Determine prime number. 2*7304104dSAndroid Build Coastguard Worker Copyright (C) 2006 Red Hat, Inc. 3*7304104dSAndroid Build Coastguard Worker This file is part of elfutils. 4*7304104dSAndroid Build Coastguard Worker Written by Ulrich Drepper <[email protected]>, 2000. 5*7304104dSAndroid Build Coastguard Worker 6*7304104dSAndroid Build Coastguard Worker This file is free software; you can redistribute it and/or modify 7*7304104dSAndroid Build Coastguard Worker it under the terms of either 8*7304104dSAndroid Build Coastguard Worker 9*7304104dSAndroid Build Coastguard Worker * the GNU Lesser General Public License as published by the Free 10*7304104dSAndroid Build Coastguard Worker Software Foundation; either version 3 of the License, or (at 11*7304104dSAndroid Build Coastguard Worker your option) any later version 12*7304104dSAndroid Build Coastguard Worker 13*7304104dSAndroid Build Coastguard Worker or 14*7304104dSAndroid Build Coastguard Worker 15*7304104dSAndroid Build Coastguard Worker * the GNU General Public License as published by the Free 16*7304104dSAndroid Build Coastguard Worker Software Foundation; either version 2 of the License, or (at 17*7304104dSAndroid Build Coastguard Worker your option) any later version 18*7304104dSAndroid Build Coastguard Worker 19*7304104dSAndroid Build Coastguard Worker or both in parallel, as here. 20*7304104dSAndroid Build Coastguard Worker 21*7304104dSAndroid Build Coastguard Worker elfutils is distributed in the hope that it will be useful, but 22*7304104dSAndroid Build Coastguard Worker WITHOUT ANY WARRANTY; without even the implied warranty of 23*7304104dSAndroid Build Coastguard Worker MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 24*7304104dSAndroid Build Coastguard Worker General Public License for more details. 25*7304104dSAndroid Build Coastguard Worker 26*7304104dSAndroid Build Coastguard Worker You should have received copies of the GNU General Public License and 27*7304104dSAndroid Build Coastguard Worker the GNU Lesser General Public License along with this program. If 28*7304104dSAndroid Build Coastguard Worker not, see <http://www.gnu.org/licenses/>. */ 29*7304104dSAndroid Build Coastguard Worker 30*7304104dSAndroid Build Coastguard Worker #include <stddef.h> 31*7304104dSAndroid Build Coastguard Worker 32*7304104dSAndroid Build Coastguard Worker 33*7304104dSAndroid Build Coastguard Worker /* Test whether CANDIDATE is a prime. */ 34*7304104dSAndroid Build Coastguard Worker static int is_prime(size_t candidate)35*7304104dSAndroid Build Coastguard Workeris_prime (size_t candidate) 36*7304104dSAndroid Build Coastguard Worker { 37*7304104dSAndroid Build Coastguard Worker /* No even number and none less than 10 will be passed here. */ 38*7304104dSAndroid Build Coastguard Worker size_t divn = 3; 39*7304104dSAndroid Build Coastguard Worker size_t sq = divn * divn; 40*7304104dSAndroid Build Coastguard Worker 41*7304104dSAndroid Build Coastguard Worker while (sq < candidate && candidate % divn != 0) 42*7304104dSAndroid Build Coastguard Worker { 43*7304104dSAndroid Build Coastguard Worker size_t old_sq = sq; 44*7304104dSAndroid Build Coastguard Worker ++divn; 45*7304104dSAndroid Build Coastguard Worker sq += 4 * divn; 46*7304104dSAndroid Build Coastguard Worker if (sq < old_sq) 47*7304104dSAndroid Build Coastguard Worker return 1; 48*7304104dSAndroid Build Coastguard Worker ++divn; 49*7304104dSAndroid Build Coastguard Worker } 50*7304104dSAndroid Build Coastguard Worker 51*7304104dSAndroid Build Coastguard Worker return candidate % divn != 0; 52*7304104dSAndroid Build Coastguard Worker } 53*7304104dSAndroid Build Coastguard Worker 54*7304104dSAndroid Build Coastguard Worker 55*7304104dSAndroid Build Coastguard Worker /* We need primes for the table size. */ 56*7304104dSAndroid Build Coastguard Worker size_t next_prime(size_t seed)57*7304104dSAndroid Build Coastguard Workernext_prime (size_t seed) 58*7304104dSAndroid Build Coastguard Worker { 59*7304104dSAndroid Build Coastguard Worker /* Make it definitely odd. */ 60*7304104dSAndroid Build Coastguard Worker seed |= 1; 61*7304104dSAndroid Build Coastguard Worker 62*7304104dSAndroid Build Coastguard Worker while (!is_prime (seed)) 63*7304104dSAndroid Build Coastguard Worker seed += 2; 64*7304104dSAndroid Build Coastguard Worker 65*7304104dSAndroid Build Coastguard Worker return seed; 66*7304104dSAndroid Build Coastguard Worker } 67