OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [net/] [snmp/] [lib/] [v2_0/] [include/] [md5.h] - Blame information for rev 308

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 27 unneback
//==========================================================================
2
//
3
//      ./lib/current/include/md5.h
4
//
5
//
6
//==========================================================================
7
//####ECOSGPLCOPYRIGHTBEGIN####
8
// -------------------------------------------
9
// This file is part of eCos, the Embedded Configurable Operating System.
10
// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
11
//
12
// eCos is free software; you can redistribute it and/or modify it under
13
// the terms of the GNU General Public License as published by the Free
14
// Software Foundation; either version 2 or (at your option) any later version.
15
//
16
// eCos is distributed in the hope that it will be useful, but WITHOUT ANY
17
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
18
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
19
// for more details.
20
//
21
// You should have received a copy of the GNU General Public License along
22
// with eCos; if not, write to the Free Software Foundation, Inc.,
23
// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
24
//
25
// As a special exception, if other files instantiate templates or use macros
26
// or inline functions from this file, or you compile this file and link it
27
// with other works to produce a work based on this file, this file does not
28
// by itself cause the resulting work to be covered by the GNU General Public
29
// License. However the source code for this file must still be made available
30
// in accordance with section (3) of the GNU General Public License.
31
//
32
// This exception does not invalidate any other reasons why a work based on
33
// this file might be covered by the GNU General Public License.
34
//
35
// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
36
// at http://sources.redhat.com/ecos/ecos-license/
37
// -------------------------------------------
38
//####ECOSGPLCOPYRIGHTEND####
39
//####UCDSNMPCOPYRIGHTBEGIN####
40
//
41
// -------------------------------------------
42
//
43
// Portions of this software may have been derived from the UCD-SNMP
44
// project,  <http://ucd-snmp.ucdavis.edu/>  from the University of
45
// California at Davis, which was originally based on the Carnegie Mellon
46
// University SNMP implementation.  Portions of this software are therefore
47
// covered by the appropriate copyright disclaimers included herein.
48
//
49
// The release used was version 4.1.2 of May 2000.  "ucd-snmp-4.1.2"
50
// -------------------------------------------
51
//
52
//####UCDSNMPCOPYRIGHTEND####
53
//==========================================================================
54
//#####DESCRIPTIONBEGIN####
55
//
56
// Author(s):    hmt
57
// Contributors: hmt
58
// Date:         2000-05-30
59
// Purpose:      Port of UCD-SNMP distribution to eCos.
60
// Description:  
61
//              
62
//
63
//####DESCRIPTIONEND####
64
//
65
//==========================================================================
66
/********************************************************************
67
       Copyright 1989, 1991, 1992 by Carnegie Mellon University
68
 
69
                          Derivative Work -
70
Copyright 1996, 1998, 1999, 2000 The Regents of the University of California
71
 
72
                         All Rights Reserved
73
 
74
Permission to use, copy, modify and distribute this software and its
75
documentation for any purpose and without fee is hereby granted,
76
provided that the above copyright notice appears in all copies and
77
that both that copyright notice and this permission notice appear in
78
supporting documentation, and that the name of CMU and The Regents of
79
the University of California not be used in advertising or publicity
80
pertaining to distribution of the software without specific written
81
permission.
82
 
83
CMU AND THE REGENTS OF THE UNIVERSITY OF CALIFORNIA DISCLAIM ALL
84
WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED
85
WARRANTIES OF MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL CMU OR
86
THE REGENTS OF THE UNIVERSITY OF CALIFORNIA BE LIABLE FOR ANY SPECIAL,
87
INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING
88
FROM THE LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
89
CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
90
CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
91
*********************************************************************/
92
/*
93
** **************************************************************************
94
** md5.h -- Header file for implementation of MD5 Message Digest Algorithm **
95
** Updated: 2/13/90 by Ronald L. Rivest                                    **
96
** (C) 1990 RSA Data Security, Inc.                                        **
97
** **************************************************************************
98
*/
99
 
100
#ifndef MD5_H
101
#define MD5_H
102
 
103
#ifdef __cplusplus
104
extern "C" {
105
#endif
106
 
107
 
108
/* MDstruct is the data structure for a message digest computation.
109
*/
110
typedef struct {
111
  unsigned int buffer[4];    /* Holds 4-word result of MD computation */
112
  unsigned char count[8];    /* Number of bits processed so far */
113
  unsigned int done;         /* Nonzero means MD computation finished */
114
} MDstruct, *MDptr;
115
 
116
/* MDbegin(MD)
117
** Input: MD -- an MDptr
118
** Initialize the MDstruct prepatory to doing a message digest computation.
119
*/
120
extern void MDbegin (MDptr);
121
 
122
/* MDupdate(MD,X,count)
123
** Input: MD -- an MDptr
124
**        X -- a pointer to an array of unsigned characters.
125
**        count -- the number of bits of X to use (an unsigned int).
126
** Updates MD using the first ``count'' bits of X.
127
** The array pointed to by X is not modified.
128
** If count is not a multiple of 8, MDupdate uses high bits of last byte.
129
** This is the basic input routine for a user.
130
** The routine terminates the MD computation when count < 512, so
131
** every MD computation should end with one call to MDupdate with a
132
** count less than 512.  Zero is OK for a count.
133
*/
134
extern int MDupdate (MDptr, unsigned char *, unsigned int);
135
 
136
/* MDprint(MD)
137
** Input: MD -- an MDptr
138
** Prints message digest buffer MD as 32 hexadecimal digits.
139
** Order is from low-order byte of buffer[0] to high-order byte of buffer[3].
140
** Each byte is printed with high-order hexadecimal digit first.
141
*/
142
extern void MDprint (MDptr);
143
 
144
int MDchecksum(u_char *data, size_t len, u_char *mac, size_t maclen);
145
int  MDsign(u_char *data, size_t len, u_char *mac, size_t maclen,
146
            u_char *secret, size_t secretlen);
147
void MDget(MDstruct *MD, u_char *buf, size_t buflen);
148
 
149
/*
150
** End of md5.h
151
****************************(cut)*****************************************/
152
#ifdef __cplusplus
153
}
154
#endif
155
 
156
#endif /* MD5_H */
157
 

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.