Museum

Home

Lab Overview

Retrotechnology Articles

⇒ Online Manual

Media Vault

Software Library

Restoration Projects

Artifacts Sought

Related Articles

crypt(3X)

getpass(3C)

passwd(4)

login(1)

passwd(1)



          CRYPT(3C)            INTERACTIVE UNIX System            CRYPT(3C)



          NAME
               crypt, setkey, encrypt - generate hashing encryption

          SYNOPSIS
               char *crypt (key, salt)
               char *key, *salt;

               void setkey (key)
               char *key;

               void encrypt (block, ignored)
               char *block;
               int ignored;

          DESCRIPTION
               The crypt function is the password encryption function.  It
               is based on a one-way hashing encryption algorithm with
               variations intended (among other things) to frustrate use of
               hardware implementations of a key search.

               Key is a user's typed password.  Salt is a two-character
               string chosen from the set [a-zA-Z0-9./]; this string is
               used to perturb the hashing algorithm in one of 4096 dif-
               ferent ways, after which the password is used as the key to
               encrypt repeatedly a constant string.  The returned value
               points to the encrypted password.  The first two characters
               are the salt itself.

               The setkey and encrypt entries provide (rather primitive)
               access to the actual hashing algorithm.  The argument of
               setkey is a character array of length 64 containing only the
               characters with numerical value 0 and 1.  If this string is
               divided into groups of 8, the low-order bit in each group is
               ignored; this gives a 56-bit key which is set into the
               machine.  This is the key that will be used with the hashing
               algorithm to encrypt the string block with the function
               encrypt.

               The argument to the encrypt entry is a character array of
               length 64 containing only the characters with numerical
               value 0 and 1.  The argument array is modified in place to a
               similar array representing the bits of the argument after
               having been subjected to the hashing algorithm using the key
               set by setkey.  Ignored is unused by encrypt but it must be
               present.

          SEE ALSO
               crypt(3X), getpass(3C), passwd(4).
               login(1), passwd(1) in the INTERACTIVE UNIX System
               User's/System Administrator's Reference Manual.

          CAVEAT
               The return value points to static data that are overwritten


          Rev. C Software Development Set                            Page 1





          CRYPT(3C)            INTERACTIVE UNIX System            CRYPT(3C)



               by each call.






















































          Rev. C Software Development Set                            Page 2



Typewritten Software • bear@typewritten.org • Edmonds, WA 98026