* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
-#include <vlc/vlc.h>
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <vlc_common.h>
#include <vlc_rand.h>
#ifndef WIN32
#include <fcntl.h>
#include <unistd.h>
#include <pthread.h>
+#include <vlc_charset.h>
#include <vlc_md5.h>
uint8_t key[BLOCK_SIZE];
/* Get non-predictible value as key for HMAC */
- int fd = open (randfile, O_RDONLY);
+ int fd = utf8_open (randfile, O_RDONLY);
if (fd == -1)
return; /* Uho! */
{
HCRYPTPROV hProv;
size_t count = len;
+ uint8_t *p_buf = (uint8_t *)buf;
/* fill buffer with pseudo-random data */
while (count > 0)
{
unsigned int val;
- val = rand();
- if (count < sizeof (val))
- {
- memcpy (buf, &val, count);
- break;
- }
-
- memcpy (buf, &val, sizeof (val));
- count -= sizeof (val);
+ val = rand();
+ if (count < sizeof (val))
+ {
+ memcpy (p_buf, &val, count);
+ break;
+ }
+
+ memcpy (p_buf, &val, sizeof (val));
+ count -= sizeof (val);
+ p_buf += sizeof (val);
}
/* acquire default encryption context */
if( CryptAcquireContext(
- &hProv, // Variable to hold returned handle.
- NULL, // Use default key container.
- MS_DEF_PROV, // Use default CSP.
- PROV_RSA_FULL, // Type of provider to acquire.
- 0) )
+ &hProv, // Variable to hold returned handle.
+ NULL, // Use default key container.
+ MS_DEF_PROV, // Use default CSP.
+ PROV_RSA_FULL, // Type of provider to acquire.
+ 0) )
{
/* fill buffer with pseudo-random data, intial buffer content
- is used as auxillary random seed */
+ is used as auxillary random seed */
CryptGenRandom(hProv, len, buf);
- CryptReleaseContext(hProv, 0);
+ CryptReleaseContext(hProv, 0);
}
}
#endif