/[gentoo-x86]/eclass/linux-mod.eclass
Gentoo

Diff of /eclass/linux-mod.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.19 Revision 1.36
1# Copyright 1999-2004 Gentoo Foundation 1# Copyright 1999-2004 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/linux-mod.eclass,v 1.19 2005/01/15 21:19:02 johnm Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/linux-mod.eclass,v 1.36 2005/04/25 18:47:12 johnm Exp $
4 4
5# Description: This eclass is used to interface with linux-info in such a way 5# Description: This eclass is used to interface with linux-info in such a way
6# to provide the functionality required and initial functions 6# to provide the functionality required and initial functions
7# required to install external modules against a kernel source 7# required to install external modules against a kernel source
8# tree. 8# tree.
13# Please direct your bugs to the current eclass maintainer :) 13# Please direct your bugs to the current eclass maintainer :)
14 14
15# A Couple of env vars are available to effect usage of this eclass 15# A Couple of env vars are available to effect usage of this eclass
16# These are as follows: 16# These are as follows:
17# 17#
18# Env Var Option Default Description 18# Env Var Option Default Description
19# KERNEL_DIR <string> /usr/src/linux The directory containing kernel 19# KERNEL_DIR <string> /usr/src/linux The directory containing kernel
20# the target kernel sources. 20# the target kernel sources.
21# ECONF_PARAMS <string> The parameters to pass to econf.
22# If this is not set, then econf
23# isn't run.
21# BUILD_PARAMS <string> The parameters to pass to make. 24# BUILD_PARAMS <string> The parameters to pass to emake.
22# BUILD_TARGETS <string> clean modules The build targets to pass to make. 25# BUILD_TARGETS <string> clean modules The build targets to pass to
26# make.
23# MODULE_NAMES <string> This is the modules which are 27# MODULE_NAMES <string> This is the modules which are
24# to be built automatically using the 28# to be built automatically using
25# default pkg_compile/install. They 29# the default pkg_compile/install.
26# are explained properly below. 30# They are explained properly
27# It will only make BUILD_TARGETS once 31# below. It will only make
32# BUILD_TARGETS once in any
28# in any directory. 33# directory.
29# NO_MODULESD <string> Set this to something to prevent
30# modulesd file generation
31
32 34
33# MODULE_NAMES - Detailed Overview 35# MODULE_NAMES - Detailed Overview
34# 36#
35# The structure of each MODULE_NAMES entry is as follows: 37# The structure of each MODULE_NAMES entry is as follows:
36# modulename(libmodulesdir:modulesourcedir) 38# modulename(libdir:srcdir:objdir)
37# for example: 39# for example:
38# MODULE_NAMES="module_pci(pci:${S}/pci) module_usb(usb:${S}/usb)" 40# MODULE_NAMES="module_pci(pci:${S}/pci:${S}) module_usb(usb:${S}/usb:${S})"
39# 41#
40# what this would do is 42# what this would do is
41# cd ${S}/pci 43# cd ${S}/pci
42# make ${BUILD_PARAMS} ${BUILD_TARGETS} 44# make ${BUILD_PARAMS} ${BUILD_TARGETS}
45# cd ${S}
43# insinto /lib/modules/${KV_FULL}/pci 46# insinto /lib/modules/${KV_FULL}/pci
44# doins module_pci.${KV_OBJ} 47# doins module_pci.${KV_OBJ}
45# 48#
46# cd ${S}/usb 49# cd ${S}/usb
47# make ${BUILD_PARAMS} ${BUILD_TARGETS} 50# make ${BUILD_PARAMS} ${BUILD_TARGETS}
51# cd ${S}
48# insinto /lib/modules/${KV_FULL}/usb 52# insinto /lib/modules/${KV_FULL}/usb
49# doins module_usb.${KV_OBJ} 53# doins module_usb.${KV_OBJ}
50# 54#
51# if the modulessourcedir isnt specified, it assumes ${S} 55# if the srcdir isnt specified, it assumes ${S}
52# if the libmodulesdir isnt specified, it assumes misc. 56# if the libdir isnt specified, it assumes misc.
53# if no seperator is defined ":" then it assumes the argument is modulesourcedir 57# if the objdir isnt specified, it assumes srcdir
58
59# There is also support for automatyed modules.d file generation.
60# This can be explicitly enabled by setting any of the following variables.
61#
62#
63# MODULESD_${modulename}_ENABLED This enables the modules.d file
64# generation even if we dont
65# specify any additional info.
66# MODULESD_${modulename}_EXAMPLES This is a bash array containing
67# a list of examples which should
68# be used. If you want us to try and
69# take a guess. Set this to "guess"
70# MODULESD_${modulename}_ALIASES This is a bash array containing
71# a list of associated aliases.
72# MODULESD_${modulename}_ADDITIONS This is a bash array containing
73# A list of additional things to
74# add to the bottom of the file.
75# This can be absolutely anything.
76# Each entry is a new line.
77# MODULES_${modulename}_DOCS This is a string list which contains
78# the full path to any associated
79# documents for $modulename
80
54 81
55inherit linux-info 82inherit linux-info
56ECLASS=linux-mod 83ECLASS=linux-mod
57INHERITED="$INHERITED $ECLASS" 84INHERITED="$INHERITED $ECLASS"
58EXPORT_FUNCTIONS pkg_setup src_install pkg_postinst src_compile 85EXPORT_FUNCTIONS pkg_setup pkg_postinst src_install src_compile
59 86
87SLOT="0"
60DESCRIPTION="Based on the $ECLASS eclass" 88DESCRIPTION="Based on the $ECLASS eclass"
61SLOT=0
62DEPEND="virtual/linux-sources 89DEPEND="virtual/linux-sources
63 sys-apps/sed 90 sys-apps/sed
64 virtual/modutils" 91 virtual/modutils
92 pcmcia? ( sys-apps/pcmcia-cs )"
65 93
66# eclass utilities 94# eclass utilities
67# ---------------------------------- 95# ----------------------------------
96
97unpack_pcmcia_sources() {
98 # So while the two eclasses exist side-by-side and also the ebuilds inherit
99 # both we need to check for PCMCIA_SOURCE_DIR, and if we find it, then we
100 # bail out and assume pcmcia.eclass is working on it.
101 [[ -n ${PCMCIA_SOURCE_DIR} ]] && return 1
102
103 if [[ -f "${1}" ]]; then
104 PCMCIA_SOURCE_DIR="${WORKDIR}/pcmcia-cs/"
105
106 ebegin "Decompressing pcmcia-cs sources"
107 mkdir -p ${PCMCIA_SOURCE_DIR}
108 tar -xjf ${1} -C ${PCMCIA_SOURCE_DIR}
109 eend $?
110
111 if [[ -f ${PCMCIA_SOURCE_DIR}/pcmcia-cs-version ]]; then
112 PCMCIA_VERSION=$(cat ${PCMCIA_SOURCE_DIR}/pcmcia-cs-version)
113 einfo "Found pcmcia-cs-${PCMCIA_VERSION}"
114 fi
115 fi
116}
117
118# Dummy function for compatibility.
119pcmcia_configure() { return 0; }
120
121pcmcia_src_unpack() {
122 local pcmcia_tbz="${ROOT}/usr/src/pcmcia-cs/pcmcia-cs-build-env.tbz2"
123
124 # if the kernel has pcmcia support built in, then we just ignore all this.
125 if linux_chkconfig_present PCMCIA; then
126 einfo "Kernel based PCMCIA support has been detected."
127 else
128 if kernel_is 2 4; then
129 unpack_pcmcia_sources ${pcmcia_tbz};
130 else
131 einfo "We have detected that you are running a 2.6 kernel"
132 einfo "but you are not using the built-in PCMCIA support."
133 einfo "We will assume you know what you are doing, but please"
134 einfo "consider using the built in PCMCIA support instead."
135 sleep 10
136
137 unpack_pcmcia_sources ${pcmcia_tbz};
138 fi
139 fi
140}
68 141
69use_m() { 142use_m() {
70 # if we haven't determined the version yet, we need too. 143 # if we haven't determined the version yet, we need too.
71 get_version; 144 get_version;
72 145
75 [ ${KV_MAJOR} -eq 2 -a ${KV_MINOR} -gt 5 -a ${KV_PATCH} -gt 5 ] && \ 148 [ ${KV_MAJOR} -eq 2 -a ${KV_MINOR} -gt 5 -a ${KV_PATCH} -gt 5 ] && \
76 return 0 || return 1 149 return 0 || return 1
77} 150}
78 151
79convert_to_m() { 152convert_to_m() {
80 [ ! -f "${1}" ] && die "convert_to_m() requires a filename as an argument"
81 if use_m 153 if use_m
82 then 154 then
155 [ ! -f "${1}" ] && \
156 die "convert_to_m() requires a filename as an argument"
83 ebegin "Converting ${1/${WORKDIR}\//} to use M= instead of SUBDIRS=" 157 ebegin "Converting ${1/${WORKDIR}\//} to use M= instead of SUBDIRS="
84 sed -i 's:SUBDIRS=:M=:g' ${1} 158 sed -i 's:SUBDIRS=:M=:g' ${1}
85 eend $? 159 eend $?
86 fi 160 fi
87} 161}
103 ewarn 177 ewarn
104 fi 178 fi
105} 179}
106 180
107update_modules() { 181update_modules() {
108 if [ -x /sbin/modules-update ] ; 182 if [ -x /sbin/modules-update ] && \
109 then 183 grep -v -e "^#" -e "^$" ${D}/etc/modules.d/* >/dev/null 2>&1; then
110 ebegin "Updating modules.conf" 184 ebegin "Updating modules.conf"
111 /sbin/modules-update 185 /sbin/modules-update
112 eend $? 186 eend $?
113 fi 187 fi
114} 188}
118 then 192 then
119 KV_OBJ="ko" 193 KV_OBJ="ko"
120 else 194 else
121 KV_OBJ="o" 195 KV_OBJ="o"
122 fi 196 fi
197 # Do we really need to know this?
198 # Lets silence it.
123 einfo "Using KV_OBJ=${KV_OBJ}" 199 # einfo "Using KV_OBJ=${KV_OBJ}"
124} 200}
125 201
126generate_modulesd() { 202generate_modulesd() {
127 # This function will generate the neccessary modules.d file from the 203 # This function will generate the neccessary modules.d file from the
128 # information contained in the modules exported parms 204 # information contained in the modules exported parms
129 205
130 local selectedmodule selectedmodule_full selectedmodulevars parameter modinfop arg xifs temp 206 local currm_path currm t myIFS myVAR
131 local module_docs module_opts module_aliases module_config 207 local module_docs module_enabled module_aliases \
132 208 module_additions module_examples module_modinfo module_opts
133 for arg in ${@}
134 do
135 selectedmodule_full="${arg}"
136 # strip the directory
137 selectedmodule="${selectedmodule_full/*\//}"
138 # convert the modulename to uppercase
139 selectedmodule="$(echo ${selectedmodule} | tr '[:lower:]' '[:upper:]')"
140 209
141 module_docs="MODULESD_${selectedmodule}_DOCS" 210 for currm_path in ${@}
211 do
212 currm=${currm_path//*\/}
213 currm=$(echo ${currm} | tr '[:lower:]' '[:upper:]')
214
215 module_docs="$(eval echo \${MODULESD_${currm}_DOCS})"
216 module_enabled="$(eval echo \${MODULESD_${currm}_ENABLED})"
142 module_aliases="$(eval echo \$\{#MODULESD_${selectedmodule}_ALIASES[*]\})" 217 module_aliases="$(eval echo \${#MODULESD_${currm/-/_}_ALIASES[*]})"
218 module_additions="$(eval echo \${#MODULESD_${currm/-/_}_ADDITIONS[*]})"
219 module_examples="$(eval echo \${#MODULESD_${currm/-/_}_EXAMPLES[*]})"
220
143 [ ${module_aliases} == 0 ] && unset module_aliases 221 [[ ${module_aliases} -eq 0 ]] && unset module_aliases
144 module_docs="${!module_docs}" 222 [[ ${module_additions} -eq 0 ]] && unset module_additions
145 modinfop="$(modinfo -p ${selectedmodule_full}.${KV_OBJ})" 223 [[ ${module_examples} -eq 0 ]] && unset module_examples
146 224
147 # By now we know if there is anything we can use to generate a file with 225 # If we specify we dont want it, then lets exit, otherwise we assume
148 # so unset empty vars and bail out if we find nothing. 226 # that if its set, we do want it.
227 [[ ${module_enabled} == no ]] && return 0
228
229 # unset any unwanted variables.
149 for parameter in ${!module_*} 230 for t in ${!module_*}
150 do 231 do
151 [ -z "${!parameter}" ] && unset ${parameter} 232 [[ -z ${!t} ]] && unset ${t}
152 done 233 done
153 [ -z "${!module_*}" -a -z "${modinfop}" ] && return
154 234
155 #so now we can set the configfilevar 235 [[ -z ${!module_*} ]] && return 0
236
237 # OK so now if we have got this far, then we know we want to continue
238 # and generate the modules.d file.
239 module_modinfo="$(modinfo -p ${currm_path}.${KV_OBJ})"
156 module_config="${T}/modulesd-${selectedmodule}" 240 module_config="${T}/modulesd-${currm}"
157 241
158 # and being working on things.
159 ebegin "Preparing file for modules.d" 242 ebegin "Preparing file for modules.d"
243 #-----------------------------------------------------------------------
160 echo "# modules.d config file for ${selectedmodule}" >> ${module_config} 244 echo "# modules.d configuration file for ${currm}" >> ${module_config}
161 echo "# this file was automatically generated from linux-mod.eclass" >> ${module_config} 245 #-----------------------------------------------------------------------
246 [[ -n ${module_docs} ]] && \
247 echo "# For more information please read:" >> ${module_config}
162 for temp in ${module_docs} 248 for t in ${module_docs}
163 do 249 do
164 echo "# Please read ${temp/*\//} for more info" >> ${module_config} 250 echo "# ${t//*\/}" >> ${module_config}
165 done 251 done
166
167 if [ ${module_aliases} > 0 ];
168 then
169 echo >> ${module_config} 252 echo >> ${module_config}
253
254 #-----------------------------------------------------------------------
255 if [[ ${module_aliases} -gt 0 ]]
256 then
170 echo "# Internal Aliases - Do not edit" >> ${module_config} 257 echo "# Internal Aliases - Do not edit" >> ${module_config}
171 echo "# ------------------------------" >> ${module_config} 258 echo "# ------------------------------" >> ${module_config}
172 259
173 (( module_aliases-- )) 260 for((t=0; t<${module_aliases}; t++))
174 for temp in $(seq 0 ${module_aliases})
175 do 261 do
176 echo "alias $(eval echo \$\{MODULESD_${selectedmodule}_ALIASES[$temp]\})" >> ${module_config} 262 echo "alias $(eval echo \${MODULESD_${currm}_ALIASES[$t]})" \
263 >> ${module_config}
177 done 264 done
265 echo '' >> ${module_config}
178 fi 266 fi
179 267
180 # and then stating any module parameters defined from the module 268 #-----------------------------------------------------------------------
181 if [ -n "${modinfop}" ]; 269 if [[ -n ${module_modinfo} ]]
182 then 270 then
183 echo >> ${module_config} 271 echo >> ${module_config}
184 echo "# Configurable module parameters" >> ${module_config} 272 echo "# Configurable module parameters" >> ${module_config}
185 echo "# ------------------------------" >> ${module_config} 273 echo "# ------------------------------" >> ${module_config}
274 myIFS="${IFS}"
275 IFS="$(echo -en "\n\b")"
276
277 for t in ${module_modinfo}
278 do
279 myVAR="$(echo ${t#*:} | grep -e " [0-9][ =]" | sed "s:.*\([01][= ]\).*:\1:")"
280 if [[ -n ${myVAR} ]]
281 then
282 module_opts="${module_opts} ${t%%:*}:${myVAR}"
283 fi
284 echo -e "# ${t%%:*}:\t${t#*:}" >> ${module_config}
285 done
286 IFS="${myIFS}"
287 echo '' >> ${module_config}
288 fi
289
290 #-----------------------------------------------------------------------
291 if [[ $(eval echo \${MODULESD_${currm}_ALIASES[0]}) == guess ]]
292 then
293 # So lets do some guesswork eh?
294 if [[ -n ${module_opts} ]]
295 then
296 echo "# For Example..." >> ${module_config}
297 echo "# --------------" >> ${module_config}
298 for t in ${module_opts}
299 do
300 echo "# options ${currm} ${t//:*}=${t//*:}" >> ${module_config}
301 done
302 echo '' >> ${module_config}
303 fi
304 elif [[ ${module_examples} -gt 0 ]]
305 then
306 echo "# For Example..." >> ${module_config}
307 echo "# --------------" >> ${module_config}
308 for((t=0; t<${module_examples}; t++))
309 do
310 echo "options $(eval echo \${MODULESD_${currm}_EXAMPLES[$t]})" \
311 >> ${module_config}
312 done
313 echo '' >> ${module_config}
314 fi
315
316 #-----------------------------------------------------------------------
317 if [[ ${module_additions} -gt 0 ]]
318 then
319 for((t=0; t<${module_additions}; t++))
320 do
321 echo "$(eval echo \${MODULESD_${currm}_ADDITIONS[$t]})" \
322 >> ${module_config}
323 done
324 echo '' >> ${module_config}
325 fi
186 326
187 xifs="${IFS}" 327 #-----------------------------------------------------------------------
188 IFS="$(echo -en "\n\b")" 328
189 for parameter in ${modinfop}
190 do
191 temp="$(echo ${parameter#*:} | grep -e " [0-9][ =]" | sed "s:.*\([01][= ]\).*:\1:")"
192 if [ -n "${temp}" ];
193 then
194 module_opts="${module_opts} ${parameter%%:*}:${temp}"
195 fi
196 echo -e "# ${parameter%%:*}:\t${parameter#*:}" >> ${module_config}
197 done
198 IFS="${xifs}"
199 fi
200
201 # and any examples we can gather from them
202 if [ -n "${module_opts}" ];
203 then
204 echo >> ${module_config}
205 echo "# For Example..." >> ${module_config}
206 echo "# ------------------------------" >> ${module_config}
207 for parameter in ${module_opts}
208 do
209 echo "# options ${selectedmodule_full/*\//} ${parameter//:*}=${parameter//*:}" >> ${module_config}
210 done
211 fi
212
213 # then we install it 329 # then we install it
214 insinto /etc/modules.d 330 insinto /etc/modules.d
215 newins ${module_config} ${selectedmodule_full/*\//} 331 newins ${module_config} ${currm_path//*\/}
216 332
217 # and install any documentation we might have. 333 # and install any documentation we might have.
218 [ -n "${module_docs}" ] && dodoc ${module_docs} 334 [[ -n ${module_docs} ]] && dodoc ${module_docs}
219 done 335 done
220 eend 0 336 eend 0
337 return 0
221} 338}
222 339
223display_postinst() { 340display_postinst() {
224 # if we haven't determined the version yet, we need too. 341 # if we haven't determined the version yet, we need too.
225 get_version; 342 get_version;
227 local modulename moduledir sourcedir moduletemp file i 344 local modulename moduledir sourcedir moduletemp file i
228 345
229 file=${ROOT}/etc/modules.autoload.d/kernel-${KV_MAJOR}.${KV_MINOR} 346 file=${ROOT}/etc/modules.autoload.d/kernel-${KV_MAJOR}.${KV_MINOR}
230 file=${file/\/\///} 347 file=${file/\/\///}
231 348
349 for i in ${MODULE_IGNORE}
350 do
351 MODULE_NAMES=${MODULE_NAMES//${i}(*}
352 done
353
354 if [[ -n ${MODULE_NAMES} ]]
355 then
232 einfo "If you would like to load this module automatically upon boot" 356 einfo "If you would like to load this module automatically upon boot"
233 einfo "please type the following as root:" 357 einfo "please type the following as root:"
234 for i in ${MODULE_NAMES} 358 for i in ${MODULE_NAMES}
235 do 359 do
236 moduletemp="$(echo ${i} | sed -e "s:\(.*\)(\(.*\)):\1 \2:")" 360 unset libdir srcdir objdir
237 modulename="${moduletemp/ */}" 361 for n in $(find_module_params ${i})
238 moduletemp="${moduletemp/* /}" 362 do
239 # if we specify two args, then we can set moduledir 363 eval ${n/:*}=${n/*:/}
240 [ -z "${moduletemp/*:*/}" ] && moduledir="${moduletemp/:*/}" 364 done
241 # if we didnt pass the brackets, then we shouldnt accept anything
242 [ -n "${moduletemp/${modulename}/}" ] && sourcedir="${moduletemp/*:/}"
243 moduledir="${moduledir:-misc}"
244 sourcedir="${sourcedir:-${S}}"
245
246 einfo " # echo \"${modulename}\" >> ${file}" 365 einfo " # echo \"${modulename}\" >> ${file}"
247 done 366 done
248 echo 367 einfo
368 fi
249} 369}
250 370
251find_module_params() { 371find_module_params() {
252 local matched_offset=0 matched_opts=0 test="${@}" temp_var result 372 local matched_offset=0 matched_opts=0 test="${@}" temp_var result
253 local i=0 y=0 z=0 373 local i=0 y=0 z=0
297 check_modules_supported; 417 check_modules_supported;
298 set_kvobj; 418 set_kvobj;
299} 419}
300 420
301linux-mod_src_compile() { 421linux-mod_src_compile() {
302 local modulename libdir srcdir objdir i n 422 local modulename libdir srcdir objdir i n myARCH="${ARCH}"
303 423 unset ARCH
424
304 BUILD_TARGETS=${BUILD_TARGETS:-clean module} 425 BUILD_TARGETS=${BUILD_TARGETS:-clean module}
426
427 for i in ${MODULE_IGNORE}
428 do
305 MODULE_NAMES=${MODULE_NAMES//${MODULE_IGNORE}} 429 MODULE_NAMES=${MODULE_NAMES//${i}(*}
430 done
306 431
307 for i in ${MODULE_NAMES} 432 for i in ${MODULE_NAMES}
308 do 433 do
434 unset libdir srcdir objdir
309 for n in $(find_module_params ${i}) 435 for n in $(find_module_params ${i})
310 do 436 do
311 eval ${n/:*}=${n/*:/} 437 eval ${n/:*}=${n/*:/}
312 done 438 done
313 libdir=${libdir:-misc} 439 libdir=${libdir:-misc}
316 442
317 if [ ! -f "${srcdir}/.built" ]; 443 if [ ! -f "${srcdir}/.built" ];
318 then 444 then
319 cd ${srcdir} 445 cd ${srcdir}
320 einfo "Preparing ${modulename} module" 446 einfo "Preparing ${modulename} module"
447 if [[ -n ${ECONF_PARAMS} ]]
448 then
449 econf ${ECONF_PARAMS} || \
450 die "Unable to run econf ${ECONF_PARAMS}"
451 fi
452
321 env -u ARCH emake ${BUILD_FIXES} ${BUILD_PARAMS} ${BUILD_TARGETS} \ 453 emake ${BUILD_FIXES} ${BUILD_PARAMS} ${BUILD_TARGETS} \
322 || die "Unable to make \ 454 || die "Unable to make \
323 ${BUILD_FIXES} ${BUILD_PARAMS} ${BUILD_TARGETS}." 455 ${BUILD_FIXES} ${BUILD_PARAMS} ${BUILD_TARGETS}."
324 touch ${srcdir}/.built 456 touch ${srcdir}/.built
325 cd ${OLDPWD} 457 cd ${OLDPWD}
326 fi 458 fi
327 done 459 done
460
461 ARCH="${myARCH}"
328} 462}
329 463
330linux-mod_src_install() { 464linux-mod_src_install() {
331 local modulename libdir srcdir objdir i n 465 local modulename libdir srcdir objdir i n
466
467 for i in ${MODULE_IGNORE}
468 do
469 MODULE_NAMES=${MODULE_NAMES//${i}(*}
470 done
332 471
333 for i in ${MODULE_NAMES} 472 for i in ${MODULE_NAMES}
334 do 473 do
474 unset libdir srcdir objdir
335 for n in $(find_module_params ${i}) 475 for n in $(find_module_params ${i})
336 do 476 do
337 eval ${n/:*}=${n/*:/} 477 eval ${n/:*}=${n/*:/}
338 done 478 done
339 libdir=${libdir:-misc} 479 libdir=${libdir:-misc}
340 srcdir=${srcdir:-${S}} 480 srcdir=${srcdir:-${S}}
341 objdir=${objdir:-${srcdir}} 481 objdir=${objdir:-${srcdir}}
342 482
343 einfo "Installing ${modulename} module" 483 einfo "Installing ${modulename} module"
344 cd ${objdir} 484 cd ${objdir}
345
346 insinto /lib/modules/${KV_FULL}/${libdir} 485 insinto ${ROOT}lib/modules/${KV_FULL}/${libdir}
347 doins ${modulename}.${KV_OBJ} 486 doins ${modulename}.${KV_OBJ}
348 cd ${OLDPWD} 487 cd ${OLDPWD}
349 488
350 [ -z "${NO_MODULESD}" ] && generate_modulesd ${objdir}/${modulename} 489 generate_modulesd ${objdir}/${modulename}
351 done 490 done
352} 491}
353 492
354linux-mod_pkg_postinst() { 493linux-mod_pkg_postinst() {
355 update_depmod; 494 update_depmod;

Legend:
Removed from v.1.19  
changed lines
  Added in v.1.36

  ViewVC Help
Powered by ViewVC 1.1.20