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