blob: 0ee436debd22c8af7c22c8819e53579ab7baf8d2 [file] [log] [blame]
Samuel Jiang9a393792019-05-23 14:59:35 +08001#!/bin/bash
2
Patrick Williams8c226232023-04-15 20:05:21 -05003export U2_PRESENT=( 148 149 150 151 152 153 154 155 )
4export POWER_U2=( 195 196 202 199 198 197 127 126 )
5export PWRGD_U2=( 161 162 163 164 165 166 167 168 )
6export RST_BMC_U2=( 72 73 74 75 76 77 78 79 )
7export PLUGGED=0
8export I2C_BUS=8
9export CHIP_ADDR=0x68
10export CLOCK_GEN_VALUE=
11
Samuel Jiang9a393792019-05-23 14:59:35 +080012CLOCK_GEN_VALUE=$(i2cget -y $I2C_BUS $CHIP_ADDR 0 i 2|cut -f3 -d' ')
13
14function set_gpio_direction()
15{
16 #$1 gpio pin, $2 'in','high','low'
Patrick Williams8c226232023-04-15 20:05:21 -050017 echo "$2" > "/sys/class/gpio/gpio$1/direction"
Samuel Jiang9a393792019-05-23 14:59:35 +080018}
19
20function read_gpio_input()
21{
22 #$1 read input gpio pin
Patrick Williams8c226232023-04-15 20:05:21 -050023 cat "/sys/class/gpio/gpio$1/value"
Samuel Jiang9a393792019-05-23 14:59:35 +080024}
25
26function enable_nvme_power()
27{
28 set_gpio_direction "${POWER_U2[$1]}" "high"
29 sleep 0.04
Patrick Williams8c226232023-04-15 20:05:21 -050030 check_powergood "$1"
Samuel Jiang9a393792019-05-23 14:59:35 +080031}
32
33function check_powergood()
34{
Patrick Williams8c226232023-04-15 20:05:21 -050035 if [ "$(read_gpio_input "${PWRGD_U2[$1]}")" == 1 ];then
Samuel Jiang9a393792019-05-23 14:59:35 +080036 sleep 0.005
Patrick Williams8c226232023-04-15 20:05:21 -050037 update_clock_gen_chip_register "$1" 1
Samuel Jiang9a393792019-05-23 14:59:35 +080038 sleep 0.1
39 set_gpio_direction "${RST_BMC_U2[$1]}" "high"
40 else
Patrick Williams8c226232023-04-15 20:05:21 -050041 disable_nvme_power "$1"
Samuel Jiang9a393792019-05-23 14:59:35 +080042 fi
43}
44
45function disable_nvme_power()
46{
47 set_gpio_direction "${RST_BMC_U2[$1]}" "low"
48 sleep 0.1
Patrick Williams8c226232023-04-15 20:05:21 -050049 update_clock_gen_chip_register "$1" 0
Samuel Jiang9a393792019-05-23 14:59:35 +080050 sleep 0.005
51 set_gpio_direction "${POWER_U2[$1]}" "low"
52}
53
54function update_clock_gen_chip_register(){
55 #$1 nvme slot number, $2 enable/disable
56 update_value=$(printf '%x\n' "$((0x01 <<$1))")
Patrick Williams8c226232023-04-15 20:05:21 -050057 if [ "$2" -eq 1 ];then
Samuel Jiang9a393792019-05-23 14:59:35 +080058 CLOCK_GEN_VALUE=$(printf '0x%x\n' \
Patrick Williams8c226232023-04-15 20:05:21 -050059 "$((CLOCK_GEN_VALUE | 0x$update_value))")
Samuel Jiang9a393792019-05-23 14:59:35 +080060 else
61 CLOCK_GEN_VALUE=$(printf '0x%x\n' \
Patrick Williams8c226232023-04-15 20:05:21 -050062 "$((CLOCK_GEN_VALUE & ~0x$update_value))")
Samuel Jiang9a393792019-05-23 14:59:35 +080063 fi
Patrick Williams8c226232023-04-15 20:05:21 -050064 i2cset -y $I2C_BUS $CHIP_ADDR 0 "$CLOCK_GEN_VALUE" s
Samuel Jiang9a393792019-05-23 14:59:35 +080065}