static void __init setup_processor(void)
 {
-       u64 features, block;
+       u64 features;
+       s64 block;
        u32 cwg;
        int cls;
 
         * for non-negative values. Negative values are reserved.
         */
        features = read_cpuid(ID_AA64ISAR0_EL1);
-       block = (features >> 4) & 0xf;
-       if (!(block & 0x8)) {
+       block = cpuid_feature_extract_field(features, 4);
+       if (block > 0) {
                switch (block) {
                default:
                case 2:
                }
        }
 
-       block = (features >> 8) & 0xf;
-       if (block && !(block & 0x8))
+       if (cpuid_feature_extract_field(features, 8) > 0)
                elf_hwcap |= HWCAP_SHA1;
 
-       block = (features >> 12) & 0xf;
-       if (block && !(block & 0x8))
+       if (cpuid_feature_extract_field(features, 12) > 0)
                elf_hwcap |= HWCAP_SHA2;
 
-       block = (features >> 16) & 0xf;
-       if (block && !(block & 0x8))
+       if (cpuid_feature_extract_field(features, 16) > 0)
                elf_hwcap |= HWCAP_CRC32;
 
-       block = (features >> 20) & 0xf;
-       if (!(block & 0x8)) {
+       block = cpuid_feature_extract_field(features, 20);
+       if (block > 0) {
                switch (block) {
                default:
                case 2:
 #ifdef CONFIG_COMPAT
        /*
         * ID_ISAR5_EL1 carries similar information as above, but pertaining to
-        * the Aarch32 32-bit execution state.
+        * the AArch32 32-bit execution state.
         */
        features = read_cpuid(ID_ISAR5_EL1);
-       block = (features >> 4) & 0xf;
-       if (!(block & 0x8)) {
+       block = cpuid_feature_extract_field(features, 4);
+       if (block > 0) {
                switch (block) {
                default:
                case 2:
                }
        }
 
-       block = (features >> 8) & 0xf;
-       if (block && !(block & 0x8))
+       if (cpuid_feature_extract_field(features, 8) > 0)
                compat_elf_hwcap2 |= COMPAT_HWCAP2_SHA1;
 
-       block = (features >> 12) & 0xf;
-       if (block && !(block & 0x8))
+       if (cpuid_feature_extract_field(features, 12) > 0)
                compat_elf_hwcap2 |= COMPAT_HWCAP2_SHA2;
 
-       block = (features >> 16) & 0xf;
-       if (block && !(block & 0x8))
+       if (cpuid_feature_extract_field(features, 16) > 0)
                compat_elf_hwcap2 |= COMPAT_HWCAP2_CRC32;
 #endif
 }