#include <sparc-ifunc.h>

#define sha256_process_block sha256_process_block_generic
extern void sha256_process_block_generic (const void *buffer, size_t len,
					  struct sha256_ctx *ctx);

#include <crypt/sha256-block.c>

#undef sha256_process_block

extern void __sha256_process_block_crop (const void *buffer, size_t len,
					 struct sha256_ctx *ctx);

static bool cpu_supports_sha256(int hwcap)
{
  unsigned long cfr;

  if (!(hwcap & HWCAP_SPARC_CRYPTO))
    return false;

  __asm__ ("rd %%asr26, %0" : "=r" (cfr));
  if (cfr & (1 << 6))
    return true;

  return false;
}

extern void sha256_process_block (const void *buffer, size_t len,
				  struct sha256_ctx *ctx);
sparc_libc_ifunc(sha256_process_block, cpu_supports_sha256(hwcap) ? __sha256_process_block_crop : sha256_process_block_generic);