[ -z "$(getprop $1)" ] && set_property "$1" "$2"
}
+function rmmod_if_exist()
+{
+ for m in $*; do
+ [ -d /sys/module/$m ] && rmmod $m
+ done
+}
+
function init_misc()
{
# device information
# enable sdcardfs if /data is not mounted on tmpfs or 9p
mount | grep /data\ | grep -qE 'tmpfs|9p'
[ $? -ne 0 ] && modprobe sdcardfs
+
+ # remove wl if it's not used
+ local wifi
+ if [ -d /sys/class/net/wlan0 ]; then
+ wifi=$(basename `readlink /sys/class/net/wlan0/device/driver`)
+ [ "$wifi" != "wl" ] && rmmod_if_exist wl
+ fi
+
+ # enable virt_wifi if needed
+ local eth=`getprop net.virt_wifi eth0`
+ if [ -d /sys/class/net/$eth -a "$VIRT_WIFI" != "0" ]; then
+ if [ -n "$wifi" -a "$VIRT_WIFI" = "1" ]; then
+ rmmod_if_exist iwlmvm $wifi
+ fi
+ if [ ! -d /sys/class/net/wlan0 ]; then
+ ifconfig $eth down
+ ip link set $eth name wifi_eth
+ ifconfig wifi_eth up
+ ip link add link wifi_eth name wlan0 type virt_wifi
+ fi
+ fi
}
function init_hal_audio()
[ "$VULKAN" = "1" ] && GRALLOC=gbm
case "$(cat /proc/fb | head -1)" in
- *virtiodrmfb)
+ *virtiodrmfb|*DRM*emulated)
if [ "$HWACCEL" != "0" ]; then
set_property ro.hardware.hwcomposer ${HWC:-drm}
set_property ro.hardware.gralloc ${GRALLOC:-gbm}
set_property debug.drm.mode.force ${video:-1280x800}
fi
;;
- 0*inteldrmfb|0*radeondrmfb|0*nouveaufb|0*svgadrmfb|0*amdgpudrmfb)
+ 0*i915drmfb|0*inteldrmfb|0*radeondrmfb|0*nouveau*|0*svgadrmfb|0*amdgpudrmfb)
if [ "$HWACCEL" != "0" ]; then
+ set_property ro.hardware.hwcomposer ${HWC:-}
set_property ro.hardware.gralloc ${GRALLOC:-drm}
set_drm_mode
fi
function init_hal_vulkan()
{
case "$(cat /proc/fb | head -1)" in
- 0*inteldrmfb)
+ 0*i915drmfb|0*inteldrmfb)
set_property ro.hardware.vulkan android-x86
;;
0*amdgpudrmfb)
local hal_sensors=kbd
local has_sensors=true
- case "$(cat $DMIPATH/uevent)" in
+ case "$UEVENT" in
*Lucid-MWE*)
set_property ro.ignore_atkbd 1
hal_sensors=hdaps
hal_sensors=hdaps
;;
*LINX1010B*)
+ set_property ro.iio.accel.x.opt_scale -1
set_property ro.iio.accel.z.opt_scale -1
+ ;;
+ *i7-WN*)
+ set_property ro.iio.accel.quirks no-trig
;&
- *i7Stylus*|*M80TA*)
+ *i7Stylus*)
set_property ro.iio.accel.x.opt_scale -1
;;
*LenovoMIIX320*|*ONDATablet*)
set_property ro.iio.accel.x.opt_scale -1
set_property ro.iio.accel.y.opt_scale -1
;;
+ *SP111-33*)
+ set_property ro.iio.accel.quirks no-trig
+ ;&
*ST70416-6*)
set_property ro.iio.accel.order 102
;;
- *e-tabPro*|*pnEZpad*)
+ *e-tabPro*|*pnEZpad*|*TECLAST:rntPAD*)
set_property ro.iio.accel.quirks no-trig
;&
- *T*0*TA*)
+ *T*0*TA*|*M80TA*)
set_property ro.iio.accel.y.opt_scale -1
;;
*)
function init_tscal()
{
- case "$PRODUCT" in
- ST70416-6*)
+ case "$UEVENT" in
+ *ST70416-6*)
modprobe gslx680_ts_acpi
;&
- T91|T101|ET2002|74499FU|945GSE-ITE8712|CF-19[CDYFGKLP]*)
+ *T91*|*T101*|*ET2002*|*74499FU*|*945GSE-ITE8712*|*CF-19[CDYFGKLP]*|*TECLAST:rntPAD*)
create_pointercal
return
;;
function init_ril()
{
- case "$(cat $DMIPATH/uevent)" in
+ case "$UEVENT" in
*TEGA*|*2010:svnIntel:*|*Lucid-MWE*)
set_property rild.libpath /system/lib/libhuaweigeneric-ril.so
set_property rild.libargs "-d /dev/ttyUSB2 -v /dev/ttyUSB1"
DMIPATH=/sys/class/dmi/id
BOARD=$(cat $DMIPATH/board_name)
PRODUCT=$(cat $DMIPATH/product_name)
+UEVENT=$(cat $DMIPATH/uevent)
# import cmdline variables
for c in `cat /proc/cmdline`; do