#!/bin/bash
#********************************************************************************#
#* *#
#* Copyright (c) 2005 Instituto Nokia de Tecnologia - INdT - Manaus Brazil *#
#* *#
#* This program is free software; you can redistribute it and#or modify *#
#* it under the terms of the GNU General Public License as published by *#
#* the Free Software Foundation; either version 2 of the License, or *#
#* (at your option) any later version. *#
#* *#
#* This program is distributed in the hope that it will be useful, *#
#* but WITHOUT ANY WARRANTY; without even the implied warranty of *#
#* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See *#
#* the GNU General Public License for more details. *#
#* *#
#* You should have received a copy of the GNU General Public License *#
#* along with this program; if not, write to the Free Software *#
#* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *#
#* *#
#********************************************************************************#
#********************************************************************************#
#* *#
#* File: ask_password.sh *#
#* *#
#* Description: get the password from userspace. It's called when unlocking *#
#* the card or assigning a new password to an unlocked card. *#
#* Return - zero on success *#
#* - non zero on failure. return value from commands ($RC) *#
#* Total Tests: 1 *#
#* *#
#* Author: Anderson Briglia <anderson.briglia@indt.org.br> *#
#* Anderson Lizardo <anderson.lizardo@indt.org.br> *#
#* Carlos Eduardo Aguiar <carlos.aguiar@indt.org.br> *#
#* *#
#* *#
#* *#
#********************************************************************************#
ask_password()
{
export TST_TOTAL=1 # Total number of test cases in this file.
# Set up LTPTMP (temporary directory used by the tests).
LTPTMP=${TMP} # Temporary directory to create files, etc.
export TCID="ask_password" # Test case identifier
export TST_COUNT=0 # Set up is initialized as test 0
RC=0 # Exit values of system commands used
USER_CONSOLE=/dev/ttyS0
{
echo "=== Unlock Protected MMC ==="
while [ -z "$passwd" ]; do
read -s -p "MMC password: " passwd; echo
done
if ! keyctl instantiate $1 "$passwd" $2 >/dev/null 2>&1; then
echo "*** Wrong password! The card was not unlocked."
exit 1
fi
echo "Password accepted."
exit 0
} >$USER_CONSOLE 2>&1 < $USER_CONSOLE
}
ask_password || exit $RC