elf.py revision 3171
293N/A# The contents of this file are subject to the terms of the 293N/A# Common Development and Distribution License (the "License"). 293N/A# You may not use this file except in compliance with the License. 293N/A# See the License for the specific language governing permissions 293N/A# and limitations under the License. 293N/A# When distributing Covered Code, include this CDDL HEADER in each 293N/A# If applicable, add the following below this CDDL HEADER, with the 293N/A# fields enclosed by brackets "[]" replaced with your own identifying 293N/A# information: Portions Copyright [yyyy] [name of copyright owner] 293N/A# Copyright (c) 2009, 2015, Oracle and/or its affiliates. All rights reserved. 844N/A """Exception that is raised when the elf dependency checker is given 1191N/A a file that errors when it tries to get the dynamic section from the 293N/A """Exception that is used for elf dependencies which have a dynamic 293N/A token in their path that we're unable to decode.""" 716N/A return _(
"{pp} (which will be installed at {ip}) had this " 293N/A "token, {tok}, in its run path: {rp}. It is not " 293N/A "currently possible to automatically expand this token. " 293N/A "Please specify its value on the command line.").
format(
293N/A """Class representing a dependency from one file to another library 293N/A as determined by elf.""" """Because elf dependencies can be either warnings or errors, it's necessary to check whether this dependency is an error """Checks whether this dependency has been delivered. If the full path has not been delivered, check whether the base name has. If it has, it's likely that the run path is being set externally. Report a warning, but not an error in this case.""" # If the none of the paths pointed to a file with the desired # basename, but a file with that basename was delivered by this # package, then treat the dependency as a warning instead of # an error. The failure to find the path to the right file # may be due to the library search path being set outside the # file that generates the dependency. """Replace dynamic tokens, such as $PLATFORM, in the paths in the paramter 'paths' with the values for that token provided in the dictionary 'dyn_tok_conv.' # The first dynamic token has been replaced, but # more may remain so process the path again. """Produce the elf dependencies for the file delivered in the action 'action' is the file action to analyze. 'pkg_vars' is the list of variants against which the package delivering the action was published. 'dyn_tok_conv' is the dictionary which maps the dynamic tokens, like $PLATFORM, to the values they should be expanded to. 'run_paths' contains the run paths which elf binaries should use. for d
in ed.
get(
"deps", [])
# For kernel modules, default path resolution is /platform/<platform>, # /kernel, /usr/kernel. But how do we know what <platform> would be for # a given module? Does it do fallbacks to, say, sun4u? # Add this platform to the search path. # Default kernel search path # What subdirectory should we look in for 64-bit kernel modules? elif ei[
"arch"] ==
"sparc":
# add our detected runpaths into the user-supplied one (if any) # Find 64-bit modules the way krtld does. # XXX We don't resolve dependencies found in # /platform, since we don't know where under # deppath includes filename; remove that.