#!/bin/sh # Copyright 2018 Intel Corporation # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. SOFS_MNT=/var/sofs SOFS_MACDIR=${SOFS_MNT}/factory-settings/network/mac read_hw_mac() { local iface="$1" cat /sys/class/net/"$iface"/address 2>/dev/null | tr [:upper:] [:lower:] 2>/dev/null } set_hw_mac() { local iface="$1" local mac="$2" ip link show dev "$iface" | grep -q "${iface}:.*\" 2>/dev/null local up=$? [[ $up -eq 0 ]] && ip link set dev "$iface" down ip link set dev "$iface" address "$mac" [[ $up -eq 0 ]] && ip link set dev "$iface" up } read_sofs_mac() { local iface="$1" cat "${SOFS_MACDIR}/${iface}" 2>/dev/null | tr [:upper:] [:lower:] 2>/dev/null } read_fw_env_mac() { local envname="$1" fw_printenv "$envname" 2>/dev/null | sed "s/^$envname=//" 2>/dev/null | tr [:upper:] [:lower:] 2>/dev/null } set_fw_env_mac() { local envname="$1" local mac="$2" fw_setenv "$envname" "$mac" } create_macdir() { if [ -a ${SOFS_MACDIR} ]; then if [ ! -d ${SOFS_MACDIR} ]; then rm -rf ${SOFS_MACDIR} mkdir -p ${SOFS_MACDIR} fi else mkdir -p ${SOFS_MACDIR} fi return 0 } # An earlier version of the mac_check utility disabled the netipmid for # eth1. This was done to eliminate an error message being logged in the # journal for systems that only had a single NIC. The error message is # undesirable as it is present in Redfish session log output. # Systems that have both NICs have also had the eth1 netipmid disabled. # The reason for this is failing to specify the correct kernel device # tree during the U-Boot kernel boot process. Without the correct # device tree, eth1 is not enumerated by the kernel. The mac-check # script turned off the netipmid service for eth1. # The configure_netipmid_svc_eth1 function manages enabling and # disabling netipmid for eth1. It is explicit, and does not rely upon # previous state to enable or disable the service. # Note: Enabling the service is independent of the IPMI channel # enable/disable command. This means "ipmitool lan set access # off" functions correctly with the netipmid service enabled. configure_netipmid_svc_eth1() { if [ -h /sys/class/net/eth1 ]; then if [ $(systemctl is-enabled phosphor-ipmi-net@eth1.socket) == "disabled" ]; then /bin/systemctl enable "phosphor-ipmi-net@eth1.socket" /bin/systemctl start "phosphor-ipmi-net@eth1.socket" fi if [ $(systemctl is-enabled phosphor-ipmi-net@eth1.service) =="disabled" ]; then /bin/systemctl enable "phosphor-ipmi-net@eth1.service" /bin/systemctl start "phosphor-ipmi-net@eth1.service" fi else if [ $(systemctl is-enabled phosphor-ipmi-net@eth1.socket) == "enabled" ]; then /bin/systemctl disable "phosphor-ipmi-net@eth1.socket" /bin/systemctl stop "phosphor-ipmi-net@eth1.socket" fi if [ $(systemctl is-enabled phosphor-ipmi-net@eth1.service) == "enabled" ]; then /bin/systemctl disable "phosphor-ipmi-net@eth1.service" /bin/systemctl stop "phosphor-ipmi-net@eth1.service" fi fi } mac_check() { local iface="$1" local envname="$2" # Read the MAC address in use by the NIC local hw_mac=$(read_hw_mac "$iface") # Read the MAC address stored in the non-volatile file provisioned in # manufacturing. local sofs_mac=$(read_sofs_mac "$iface") if [ -n "$sofs_mac" ] && [ "$hw_mac" != "$sofs_mac" ]; then # A factory assigned address was found, and it is newly assigned. # Update the active interface and save the new value to the u-boot # environment. set_hw_mac "$iface" "$sofs_mac" set_fw_env_mac "$envname" "$sofs_mac" return $? elif [ -n "$hw_mac" ]; then # Read the MAC address stored by U-Boot local fw_env_mac=$(read_fw_env_mac "$envname") if [ -z "$fw_env_mac" ] || [ "$fw_env_mac" != "$hw_mac" ]; then set_fw_env_mac "$envname" "$hw_mac" return $? fi else # Could not identify a MAC address return 255 fi return 0 } create_macdir configure_netipmid_svc_eth1 error=0 first_error_seen=0 while read IFACE UBDEV; do # Try to configure the MAC address if the kernel finds the NIC. Blindly # trying all of the interfaces listed in the DOCSTRING (END_CONF) below # may result in first_error_seen being set to a non-zero value. If that # happens the journal log will report the error, which is undesirable. if [ -h /sys/class/net/$IFACE ]; then mac_check "$IFACE" "$UBDEV" error=$? if [ $error -ne 0 ] && [ $first_error_seen -eq 0 ]; then first_error_seen=$error fi fi done <<-END_CONF eth0 eth1addr eth1 ethaddr END_CONF exit $first_error_seen