iPXE
Functions
digest_cmd.h File Reference
#include <ipxe/crypto.h>
#include <ipxe/command.h>

Go to the source code of this file.

Functions

 FILE_LICENCE (GPL2_OR_LATER_OR_UBDL)
 
int digest_exec (int argc, char **argv, struct digest_algorithm *digest)
 The "digest" command. More...
 

Function Documentation

◆ FILE_LICENCE()

FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL  )

◆ digest_exec()

int digest_exec ( int  argc,
char **  argv,
struct digest_algorithm digest 
)

The "digest" command.

Parameters
argcArgument count
argvArgument list
digestDigest algorithm
Return values
rcReturn status code

Definition at line 67 of file digest_cmd.c.

67  {
68  struct digest_options opts;
69  struct image *image;
70  uint8_t ctx[digest->ctxsize];
71  uint8_t out[digest->digestsize];
72  unsigned int j;
73  int i;
74  int rc;
75 
76  /* Parse options */
77  if ( ( rc = parse_options ( argc, argv, &digest_cmd, &opts ) ) != 0 )
78  return rc;
79 
80  /* Use default setting type, if not specified */
81  if ( ! opts.setting.setting.type )
82  opts.setting.setting.type = &setting_type_hexraw;
83 
84  /* Calculate digests for each image */
85  for ( i = optind ; i < argc ; i++ ) {
86 
87  /* Acquire image */
88  if ( ( rc = imgacquire ( argv[i], 0, &image ) ) != 0 )
89  return rc;
90 
91  /* Calculate digest */
92  digest_init ( digest, ctx );
93  digest_update ( digest, ctx, image->data, image->len );
94  digest_final ( digest, ctx, out );
95 
96  /* Display or store digest as directed */
97  if ( opts.setting.settings ) {
98 
99  /* Store digest */
100  if ( ( rc = store_setting ( opts.setting.settings,
101  &opts.setting.setting, out,
102  sizeof ( out ) ) ) != 0 ) {
103  printf ( "Could not store \"%s\": %s\n",
104  opts.setting.setting.name,
105  strerror ( rc ) );
106  return rc;
107  }
108 
109  } else {
110 
111  /* Print digest */
112  for ( j = 0 ; j < sizeof ( out ) ; j++ )
113  printf ( "%02x", out[j] );
114  printf ( " %s\n", image->name );
115  }
116  }
117 
118  return 0;
119 }
struct arbelprm_rc_send_wqe rc
Definition: arbel.h:14
static void digest_update(struct digest_algorithm *digest, void *ctx, const void *data, size_t len)
Definition: crypto.h:201
int printf(const char *fmt,...)
Write a formatted string to the console.
Definition: vsprintf.c:464
int optind
Current option index.
Definition: getopt.c:51
const void * data
Read-only data.
Definition: image.h:50
static void digest_final(struct digest_algorithm *digest, void *ctx, void *out)
Definition: crypto.h:207
int store_setting(struct settings *settings, const struct setting *setting, const void *data, size_t len)
Store value of setting.
Definition: settings.c:615
int parse_options(int argc, char **argv, struct command_descriptor *cmd, void *opts)
Parse command-line options.
Definition: parseopt.c:484
An executable image.
Definition: image.h:23
struct golan_eq_context ctx
Definition: CIB_PRM.h:28
static struct command_descriptor digest_cmd
"digest" command descriptor
Definition: digest_cmd.c:55
__be32 out[4]
Definition: CIB_PRM.h:36
"digest" options
Definition: digest_cmd.c:43
static void digest_init(struct digest_algorithm *digest, void *ctx)
Definition: crypto.h:196
char * strerror(int errno)
Retrieve string representation of error number.
Definition: strerror.c:78
size_t len
Length of raw file image.
Definition: image.h:55
unsigned char uint8_t
Definition: stdint.h:10
size_t ctxsize
Context size.
Definition: crypto.h:22
size_t digestsize
Digest size.
Definition: crypto.h:26
static union @447 opts
"cert<xxx>" option list
char * name
Name.
Definition: image.h:37
int imgacquire(const char *name_uri, unsigned long timeout, struct image **image)
Acquire an image.
Definition: imgmgmt.c:142

References ctx, digest_algorithm::ctxsize, image::data, digest_cmd, digest_final(), digest_init(), digest_update(), digest_algorithm::digestsize, imgacquire(), image::len, image::name, optind, opts, out, parse_options(), printf(), rc, store_setting(), and strerror().

Referenced by md4sum_exec(), md5sum_exec(), sha1sum_exec(), sha224sum_exec(), sha256sum_exec(), sha384sum_exec(), and sha512sum_exec().