Subversion Repositories freemyipod

Rev

Rev 2 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 2 Rev 143
Line 1... Line 1...
1
//
1
//
2
//
2
//
3
//    Copyright 2009 TheSeven
3
//    Copyright 2010 TheSeven
4
//
4
//
5
//
5
//
6
//    This file is part of the Linux4Nano toolkit.
6
//    This file is part of emBIOS.
7
//
7
//
8
//    TheSeven's iBugger is free software: you can redistribute it and/or
8
//    emBIOS is free software: you can redistribute it and/or
9
//    modify it under the terms of the GNU General Public License as
9
//    modify it under the terms of the GNU General Public License as
10
//    published by the Free Software Foundation, either version 2 of the
10
//    published by the Free Software Foundation, either version 2 of the
11
//    License, or (at your option) any later version.
11
//    License, or (at your option) any later version.
12
//
12
//
13
//    TheSeven's iBugger is distributed in the hope that it will be useful,
13
//    emBIOS is distributed in the hope that it will be useful,
14
//    but WITHOUT ANY WARRANTY; without even the implied warranty of
14
//    but WITHOUT ANY WARRANTY; without even the implied warranty of
15
//    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
15
//    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
16
//    See the GNU General Public License for more details.
16
//    See the GNU General Public License for more details.
17
//
17
//
18
//    You should have received a copy of the GNU General Public License along
18
//    You should have received a copy of the GNU General Public License along
19
//    with the Linux4Nano toolkit.  If not, see <http://www.gnu.org/licenses/>.
19
//    with emBIOS.  If not, see <http://www.gnu.org/licenses/>.
20
//
20
//
21
//
21
//
22
 
22
 
23
 
23
 
24
#include <toolkit.h>
24
#include "global.h"
25
#include <hash.h>
25
#include "hmacsha1.h"
-
 
26
#include "s5l8701.h"
-
 
27
#include "thread.h"
26
 
28
 
27
 
29
 
28
void hash(void* data, uint32_t size, void* result)
30
void hmacsha1(void* data, uint32_t size, void* result)
29
{
31
{
30
    uint32_t ptr, i;
32
    uint32_t ptr, i;
31
    uint32_t ctrl = 2;
33
    uint32_t ctrl = 2;
32
    PWRCONEXT &= ~4;
34
    PWRCON(1) &= ~4;
33
    for (ptr = 0; ptr < size; ptr += 0x10)
35
    for (ptr = 0; ptr < (size >> 2); ptr += 0x10)
34
    {
36
    {
35
      for (i = 0; i < 0x10; i++) HASHDATAIN[i] = ((uint32_t*)data)[ptr + i];
37
      for (i = 0; i < 0x10; i++) HASHDATAIN[i] = ((uint32_t*)data)[ptr + i];
36
      HASHCTRL = ctrl;
38
      HASHCTRL = ctrl;
37
      ctrl = 0xA;
39
      ctrl = 0xA;
38
      while (HASHCTRL & 1);
40
      while (HASHCTRL & 1) yield();
39
    }
41
    }
40
    for (i = 0; i < 5; i ++) ((uint32_t*)result)[i] = HASHRESULT[i];
42
    for (i = 0; i < 5; i ++) ((uint32_t*)result)[i] = HASHRESULT[i];
41
    PWRCONEXT |= 4;
43
    PWRCON(1) |= 4;
42
}
44
}