hc
2023-02-14 0cc9b7c44253c93447ddf73e206fbdbb3d9f16b1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/*
 * Copyright (C) 2014-2016, Toradex AG
 *
 * SPDX-License-Identifier:    GPL-2.0+
 */
 
/*
 * Helpers for i.MX OTP fusing during module production
*/
 
#include <common.h>
#ifndef CONFIG_SPL_BUILD
#include <console.h>
#include <fuse.h>
 
static int mfgr_fuse(void)
{
   unsigned val, val6;
 
   fuse_sense(0, 5, &val);
   printf("Fuse 0, 5: %8x\n", val);
   fuse_sense(0, 6, &val6);
   printf("Fuse 0, 6: %8x\n", val6);
   fuse_sense(4, 3, &val);
   printf("Fuse 4, 3: %8x\n", val);
   fuse_sense(4, 2, &val);
   printf("Fuse 4, 2: %8x\n", val);
   if (val6 & 0x10) {
       puts("BT_FUSE_SEL already fused, will do nothing\n");
       return CMD_RET_FAILURE;
   }
   /* boot cfg */
   fuse_prog(0, 5, 0x00005072);
   /* BT_FUSE_SEL */
   fuse_prog(0, 6, 0x00000010);
   return CMD_RET_SUCCESS;
}
 
int do_mfgr_fuse(cmd_tbl_t *cmdtp, int flag, int argc,
       char * const argv[])
{
   int ret;
   puts("Fusing...\n");
   ret = mfgr_fuse();
   if (ret == CMD_RET_SUCCESS)
       puts("done.\n");
   else
       puts("failed.\n");
   return ret;
}
 
int do_updt_fuse(cmd_tbl_t *cmdtp, int flag, int argc,
       char * const argv[])
{
   unsigned val;
   int ret;
   int confirmed = argc >= 1 && !strcmp(argv[1], "-y");
 
   /* can be used in scripts for command availability check */
   if (argc >= 1 && !strcmp(argv[1], "-n"))
       return CMD_RET_SUCCESS;
 
   /* boot cfg */
   fuse_sense(0, 5, &val);
   printf("Fuse 0, 5: %8x\n", val);
   if (val & 0x10) {
       puts("Fast boot mode already fused, no need to fuse\n");
       return CMD_RET_SUCCESS;
   }
   if (!confirmed) {
       puts("Warning: Programming fuses is an irreversible operation!\n"
               "         Updating to fast boot mode prevents easy\n"
               "         downgrading to previous BSP versions.\n"
               "\nReally perform this fuse programming? <y/N>\n");
       if (!confirm_yesno())
           return CMD_RET_FAILURE;
   }
   puts("Fusing fast boot mode...\n");
   ret = fuse_prog(0, 5, 0x00005072);
   if (ret == CMD_RET_SUCCESS)
       puts("done.\n");
   else
       puts("failed.\n");
   return ret;
}
 
U_BOOT_CMD(
   mfgr_fuse, 1, 0, do_mfgr_fuse,
   "OTP fusing during module production",
   ""
);
 
U_BOOT_CMD(
   updt_fuse, 2, 0, do_updt_fuse,
   "OTP fusing during module update",
   "updt_fuse [-n] [-y] - boot cfg fast boot mode fusing"
);
#endif /* CONFIG_SPL_BUILD */