From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Date: Tue, 5 Apr 2016 00:45:23 +0300 (MSK) From: Ivan Zakharyaschev To: ALT Linux Team development discussions In-Reply-To: Message-ID: References: User-Agent: Alpine 2.20 (LFD 67 2015-01-07) MIME-Version: 1.0 Content-Type: multipart/mixed; BOUNDARY="1807885841-716826387-1459806323=:1850" Subject: [devel] I: verify-elf for plugins etc. with RPM_LD_PRELOAD_xxxx & RPM_FILES_TO_LD_PRELOAD_xxxx; was: Re: python3-3.5 unmets X-BeenThere: devel@lists.altlinux.org X-Mailman-Version: 2.1.12 Precedence: list Reply-To: ALT Linux Team development discussions List-Id: ALT Linux Team development discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 04 Apr 2016 21:45:23 -0000 Archived-At: List-Archive: List-Post: This message is in MIME format. The first part should be readable text, while the remaining parts are likely unreadable without MIME-aware tools. --1807885841-716826387-1459806323=:1850 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8BIT On Fri, 1 Apr 2016, Ivan Zakharyaschev wrote: > (Им же в verify_elf делается LD_PRELOAD, чтобы не засорять лог сборки > несущественными сообщениями об undefined symbols. Для случая, когда > такая библиотека кладётся в системные /usr/lib/, есть макрос > %requires_python_ABI_for_files; пример -- пакет boost или > python3-module-pygobject или python-module-pygobject3. Иначе пакет не > пропустят.) Появился механизм для проверки всяких .so-плагинов на undefined symbols. Можно пользоваться (например, видел краем глаза обилие саодельных проверок в спеке apache). В качестве примера с помощью него реализована: 1. проверка всего внутри python*/site-packages/ (раньше были warnings) 2. а также макрос %requires_python3_ABI_for_files с явным указанием интересных файлов. Принцип такой, что verify-elf понимает пары переменных окружения вида RPM_LD_PRELOAD_xxxx и RPM_FILES_TO_LD_PRELOAD_xxxx (в случае одного из питоноа в качестве идентификатора вместо xxxx выбрано python3, например). Поверх этого можно реализовывать нужные Вам макросы или задействовать напрямую. Как предлагает glebfm@, чтобы ld-preload-ить программы, а не библиотеки, они должны быть PIE. -- Best regards, Ivan --1807885841-716826387-1459806323=:1850--