File: README

package info (click to toggle)
scratchbox2 2.2.4-1debian1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd, wheezy
  • size: 5,392 kB
  • ctags: 5,239
  • sloc: ansic: 21,734; sh: 4,360; perl: 2,170; cpp: 1,913; makefile: 610; python: 184
file content (172 lines) | stat: -rw-r--r-- 6,498 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172

"external_patches" for SB2:
===========================

This directory contains patches to external components that are recommended
to be used in the SB2'ed environment.

These patches are needed when:

a) target CPU archictecture is the same as host CPU architecture;
   i.e. when sb2 is used without Qemu.

b) these are also recommended for tools, when the tools are not used
   from the host OS (which is usually the case with "accel" and "devel" modes)

c) The host OS contains buggy components (this currently applies to
   64-bit Ubuntu Lucid; see detailed description below)

Short description of the files:

gdb-7.0.1+sb2.patch
-------------------

	From: Gergely Risko <gergely@risko.hu>
	
	The main problem is that sb2 wraps exec and instead of execve'ing the
	executable, it uses ld-linux.so.2 to do the loading.  This way the
	kernel only maps ld-linux.so.2, and the mmapping of the real binary is
	done by ld-linux.so.2 itself.  Thus the kernel raises SIGTRAP as soon as
	ld-linux.so.2 is mmapped, but by this time the real binary is not in the
	memory, setting breakpoints fail.

	My solution is two minimal modifications in libsb2 and gdb.

	Gdb has a
	#define START_INFERIOR_TRAPS_EXPECTED 2
	in gdb/inferior.h, which specifies that 2 SIGTRAPs will be raised, and
	then we are really debugging the wanted process.  The first SIGTRAP is
	from the shell, which is used in GDB to make e.g.
	run *
	possible (where * is expanded by the shell).  I just increased this
	constant to 4.  I also set a new environment variable SBOX_SIGTRAP to 1
	in the shell started by GDB.

	In libsb2 I added to the initialization a check.  If SBOX_SIGTRAP is
	set, then we do a raise(SIGTRAP).

	So the whole process is this:
	gdb forks
	  ptrace(TRACME)
	  execve("/bin/sh", ["-e", "./mybin"], {SBOX_SIGTRAP => "1", ...})
	    libsb2 wraps this exec:
	    exec("ld-linux.so.2", ["/bin/sh", "-e", "exec ./mybin"])  -> 1 SIGTRAP
	      libsb2.so gets loaded for the shell, constructor gets called,
	      the constructor notes the SBOX_SIGTRAP               -> 1 SIGTRAP
	      shell exec's the mybin                               -> 1 SIGTRAP
	      libsb2.so preload constructor notes SBOX_SIGTRAP     -> 1 SIGTRAP
	<-
	gdb parent already got 4 SIGTRAPs, so it starts putting in breakpoints
	and everything.

	Pro: no gdb wrapper, user can start putting breakpoints right away after
	gdb startup, no special handling of gdb is needed inside sb2.

	Con: modification in both gdb and libsb2.

	-=-

	GDB can follow exec calls, see (info "(gdb) Processes").

	To support this, SB2 has to reintroduce SBOX_SIGTRAP if it
	going to be lost because the program called exec*e without
	specifying SBOX_SIGTRAP in the new env.  This is done in
	preload/sb-exec.c:prepare_envp_for_do_exec.

	In GDB we have to wait for an extra SIGTRAP after every time,
	the inferior called exec(), the modification for this is made
	in gdb/infrun.c.

[NOTE: patches for glibc/eglibc should be applied in this order:]

glibc-2.10-ldconfig.patch
-------------------------
	A bugfix for "ldconfig" (eglibc 2.10). The bug exists in 2.8, too.
	Version 2.5 was ok.

glibc-2.3.6-elf-rtld.c.patch, glibc-2.5-elf-rtld.c.patch,
glibc-2.8-elf-rtld.c.patch, glibc-2.10-elf-rtld.c.1.patch
--------------------------------------------------------

	A small patch for the dynamic linker/loader ("ld.so", also known as
	"ld-linux.so"). The dynamic linker is part of the "glibc" package.

	This patch adds one command line option which is only used
	when the dynamic linker is started as an ordinary program,
	which is a seldom used way to start dynamically linked
	programs. SB2 uses that option to preserve semantics of the
	exec* calls

	[SB2 starts the dynamic linker as an ordinary program,
	to be able to get full control of the execution environment -
	this is somewhat complex system. Study the implementation
	of SB2's exec-related functions for full details]

	Note that this patch causes no harm in the default case, i.e.
	when the dynamic linker is started "automatically" by the kernel.

glibc-2.5-ld.so-rpath-prefix-option.patch,
glibc-2.8-ldso-rpath-prefix-option.patch,
glibc-2.10-ldso-rpath-prefix-option.2.patch
-------------------------------------------
	
	This patch adds a new option "--rpath-prefix" to ld.so.
	This makes it possible to add a prefix to all RPATH and
	RUNPATH options from binaries and libraries; that way 
	Scratchbox 2 can run also host-compatible binaries that
	contain such options (without this, the RPATHs would
	refer to the libraries on the host system and not to
	the correct libraries under 'target_root').

	Note that this patch causes no harm in the default case, i.e.
	when the dynamic linker is started "automatically" by the kernel.

glibc-2.5-nsswitchconf-location.patch,
glibc-2.8-nsswitchconf-location.patch,
glibc-2.10-nsswitchconf-location.3.patch
----------------------------------------
	This patch makes location of the /etc/nsswitch.conf file
	to be run-time configurable via an environment variable.

	This is needed for correct operation with Scratchbox 2.
	Without this, the sb2-virtualized environment will
	always read /etc/nsswitch.conf from the host.

glibc-2.5-nscd-socket-location,
glibc-2.8-nscd-socket-location.patch,
glibc-2.10-nscd-socket-location.4.patch
---------------------------------------
	This patch makes location of nscd's socket to be run-time
	configurable via an environment variable.

glibc-2.5-ldso-nodefaultdirs-option,
glibc-2.8-ldso-nodefaultdirs-option.patch,
glibc-2.10-ldso-nodefaultdirs-option.5.patch
--------------------------------------------
	Adds a new option "--nodefaultdirs" to ld.so.

	This option disables searching from the default directories
	(/lib,/usr/lib) and also disables use of ld.so's search
	cache.

	This is recommended for correct operation with Scratchbox 2;
	without this, libraries may be incorrectly loaded from the
	host environment (such libraries that are missing from
	the "scratchboxed" environment but are present in the host)

==========

ubuntu_lucid_64bit_fakeroot_fix.patch
-------------------------------------

	32-bit libfakeroot is missing from 64-bit Ubuntu Lucid
	(version 1.14.4-1ubuntu1 of fakeroot is buggy); the bug
	has been reported but haven't been fixed (Dec 16, 2010);
	https://bugs.launchpad.net/ubuntu/+source/fakeroot/+bug/571091

	To fix the problem:
	- get the sources (atp-get source fakeroot)
	- apply the patch
	- use dpkg-buidpackage
	- install the fixed version (1.14.4-1ubuntu1.1)