2014-02-26 19:11:54 +01:00
|
|
|
/*****************************************************************************
|
|
|
|
|
2016-06-21 14:21:03 +02:00
|
|
|
Copyright (c) 1994, 2016, Oracle and/or its affiliates. All Rights Reserved.
|
2019-12-09 12:17:12 +02:00
|
|
|
Copyright (c) 2019, MariaDB Corporation.
|
2014-02-26 19:11:54 +01:00
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify it under
|
|
|
|
the terms of the GNU General Public License as published by the Free Software
|
|
|
|
Foundation; version 2 of the License.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
|
|
|
this program; if not, write to the Free Software Foundation, Inc.,
|
2019-05-11 19:25:02 +03:00
|
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1335 USA
|
2014-02-26 19:11:54 +01:00
|
|
|
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
/******************************************************************//**
|
|
|
|
@file include/ut0rnd.h
|
|
|
|
Random numbers and hashing
|
|
|
|
|
|
|
|
Created 1/20/1994 Heikki Tuuri
|
|
|
|
***********************************************************************/
|
|
|
|
|
|
|
|
#ifndef ut0rnd_h
|
|
|
|
#define ut0rnd_h
|
|
|
|
|
|
|
|
#include "ut0byte.h"
|
2019-12-09 12:17:12 +02:00
|
|
|
#include <my_sys.h>
|
2014-02-26 19:11:54 +01:00
|
|
|
|
2018-11-29 12:53:44 +02:00
|
|
|
#ifndef UNIV_INNOCHECKSUM
|
2019-12-09 12:17:12 +02:00
|
|
|
/** Seed value of ut_rnd_gen() */
|
|
|
|
extern uint64_t ut_rnd_current;
|
|
|
|
|
|
|
|
/** @return a pseudo-random 64-bit number */
|
|
|
|
inline uint64_t ut_rnd_gen()
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
This is a linear congruential pseudo random number generator.
|
|
|
|
The formula and the constants
|
|
|
|
being used are:
|
|
|
|
X[n+1] = (a * X[n] + c) mod m
|
|
|
|
where:
|
|
|
|
X[0] = my_interval_timer()
|
|
|
|
a = 1103515245 (3^5 * 5 * 7 * 129749)
|
|
|
|
c = 12345 (3 * 5 * 823)
|
|
|
|
m = 18446744073709551616 (1<<64), implicit */
|
|
|
|
|
|
|
|
if (UNIV_UNLIKELY(!ut_rnd_current)) {
|
|
|
|
ut_rnd_current = my_interval_timer();
|
|
|
|
}
|
|
|
|
|
|
|
|
ut_rnd_current = 1103515245 * ut_rnd_current + 12345;
|
|
|
|
return ut_rnd_current;
|
|
|
|
}
|
2014-02-26 19:11:54 +01:00
|
|
|
|
|
|
|
/********************************************************//**
|
|
|
|
Generates a random integer from a given interval.
|
2016-08-12 11:17:45 +03:00
|
|
|
@return the 'random' number */
|
2014-02-26 19:11:54 +01:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
ut_rnd_interval(
|
|
|
|
/*============*/
|
|
|
|
ulint low, /*!< in: low limit; can generate also this value */
|
|
|
|
ulint high); /*!< in: high limit; can generate also this value */
|
2016-08-12 11:17:45 +03:00
|
|
|
|
2014-02-26 19:11:54 +01:00
|
|
|
/*******************************************************//**
|
|
|
|
The following function generates a hash value for a ulint integer
|
|
|
|
to a hash table of size table_size, which should be a prime or some
|
|
|
|
random number to work reliably.
|
2016-08-12 11:17:45 +03:00
|
|
|
@return hash value */
|
2014-02-26 19:11:54 +01:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
ut_hash_ulint(
|
|
|
|
/*==========*/
|
|
|
|
ulint key, /*!< in: value to be hashed */
|
|
|
|
ulint table_size); /*!< in: hash table size */
|
|
|
|
/*************************************************************//**
|
|
|
|
Folds a 64-bit integer.
|
2016-08-12 11:17:45 +03:00
|
|
|
@return folded value */
|
2014-02-26 19:11:54 +01:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
ut_fold_ull(
|
|
|
|
/*========*/
|
|
|
|
ib_uint64_t d) /*!< in: 64-bit integer */
|
2016-06-21 14:21:03 +02:00
|
|
|
MY_ATTRIBUTE((const));
|
2014-02-26 19:11:54 +01:00
|
|
|
/*************************************************************//**
|
|
|
|
Folds a character string ending in the null character.
|
2016-08-12 11:17:45 +03:00
|
|
|
@return folded value */
|
2014-02-26 19:11:54 +01:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
ut_fold_string(
|
|
|
|
/*===========*/
|
|
|
|
const char* str) /*!< in: null-terminated string */
|
2016-09-06 09:43:16 +03:00
|
|
|
MY_ATTRIBUTE((warn_unused_result));
|
2014-02-26 19:11:54 +01:00
|
|
|
/***********************************************************//**
|
|
|
|
Looks for a prime number slightly greater than the given argument.
|
|
|
|
The prime is chosen so that it is not near any power of 2.
|
2016-08-12 11:17:45 +03:00
|
|
|
@return prime */
|
2014-02-26 19:11:54 +01:00
|
|
|
ulint
|
|
|
|
ut_find_prime(
|
|
|
|
/*==========*/
|
|
|
|
ulint n) /*!< in: positive number > 100 */
|
2016-06-21 14:21:03 +02:00
|
|
|
MY_ATTRIBUTE((const));
|
2014-02-26 19:11:54 +01:00
|
|
|
|
|
|
|
#endif /* !UNIV_INNOCHECKSUM */
|
|
|
|
|
|
|
|
/*************************************************************//**
|
|
|
|
Folds a pair of ulints.
|
2016-08-12 11:17:45 +03:00
|
|
|
@return folded value */
|
2014-02-26 19:11:54 +01:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
ut_fold_ulint_pair(
|
|
|
|
/*===============*/
|
|
|
|
ulint n1, /*!< in: ulint */
|
|
|
|
ulint n2) /*!< in: ulint */
|
2016-06-21 14:21:03 +02:00
|
|
|
MY_ATTRIBUTE((const));
|
2014-02-26 19:11:54 +01:00
|
|
|
/*************************************************************//**
|
|
|
|
Folds a binary string.
|
2016-08-12 11:17:45 +03:00
|
|
|
@return folded value */
|
2014-02-26 19:11:54 +01:00
|
|
|
UNIV_INLINE
|
|
|
|
ulint
|
|
|
|
ut_fold_binary(
|
|
|
|
/*===========*/
|
|
|
|
const byte* str, /*!< in: string of bytes */
|
|
|
|
ulint len) /*!< in: length */
|
2016-06-21 14:21:03 +02:00
|
|
|
MY_ATTRIBUTE((pure));
|
2014-02-26 19:11:54 +01:00
|
|
|
|
|
|
|
#include "ut0rnd.ic"
|
|
|
|
|
|
|
|
#endif
|