1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- /* -*- mode:c; c-file-style:"k&r"; c-basic-offset: 4; tab-width:4; indent-tabs-mode:nil; mode:auto-fill; fill-column:78; -*- */
- /* vim: set ts=4 sw=4 et tw=78 fo=cqt wm=0: */
- /* Copyright (C) 2014 OSCAR lab, Stony Brook University
- This file is part of Graphene Library OS.
- Graphene Library OS 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, either version 3 of the
- License, or (at your option) any later version.
- Graphene Library OS 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, see <http://www.gnu.org/licenses/>. */
- /*
- * shim_random.c
- *
- * This file contains codes for generating random numbers.
- */
- #include <shim_internal.h>
- #include <shim_utils.h>
- #include <shim_checkpoint.h>
- #include <pal.h>
- static LOCKTYPE randgen_lock;
- static unsigned long randval __attribute_migratable;
- int init_randgen (void)
- {
- if (DkRandomBitsRead (&randval, sizeof(randval)) < sizeof(randval))
- return -EACCES;
- create_lock(randgen_lock);
- return 0;
- }
- int getrand (void * buffer, size_t size)
- {
- int bytes = 0;
- lock(randgen_lock);
- while (bytes + sizeof(unsigned long) <= size) {
- *(unsigned long *) (buffer + bytes) = randval;
- bytes += sizeof(unsigned long);
- randval = hash64(randval);
- }
- if (bytes < size) {
- switch (size - bytes) {
- case 4:
- *(uint32_t *) (buffer + bytes) = randval & 0xffffffff;
- bytes += 4;
- break;
- case 2:
- *(uint16_t *) (buffer + bytes) = randval & 0xffff;
- bytes += 2;
- break;
- case 1:
- *(uint8_t *) (buffer + bytes) = randval & 0xff;
- bytes++;
- break;
- default: break;
- }
- randval = hash64(randval);
- }
- unlock(randgen_lock);
- return bytes;
- }
- extern_alias(getrand);
|