Subversion Repositories Kolibri OS

Rev

Rev 5078 | Rev 5354 | Go to most recent revision | Only display areas with differences | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 5078 Rev 5271
1
# note that gcc must be at least 4.5! otherwise, use old Makefile
1
# note that gcc must be at least 4.5! otherwise, use old Makefile
2
CC = gcc
2
CC = gcc
3
LD = ld
3
LD = ld
4
AS = as
4
AS = as
5
FASM = fasm
5
FASM = fasm
6
 
6
 
-
 
7
DEFINES	 = -D__KERNEL__ -DCONFIG_X86_32 -DCONFIG_TINY_RCU -DCONFIG_X86_L1_CACHE_SHIFT=6
7
DEFINES	 = -D__KERNEL__ -DCONFIG_X86_32 
8
DEFINES += -DCONFIG_ARCH_HAS_CACHE_LINE_SIZE
8
 
9
 
9
DDK_TOPDIR      = d:\kos\kolibri\drivers\ddk
10
DDK_TOPDIR      = d:\kos\kolibri\drivers\ddk
10
DRV_INCLUDES    = /d/kos/kolibri/drivers/include
11
DRV_INCLUDES    = /d/kos/kolibri/drivers/include
11
DRM_TOPDIR   = $(CURDIR)/..
12
DRM_TOPDIR   = $(CURDIR)/..
12
 
13
 
13
INCLUDES = 	-I$(DRV_INCLUDES)/linux/uapi -I$(DRV_INCLUDES)/linux \
14
INCLUDES =	-I$(DRV_INCLUDES)	\
14
                -I$(DRV_INCLUDES)/linux/asm -I$(DRV_INCLUDES)/drm \
15
		-I$(DRV_INCLUDES)/asm 	\
15
		-I./ -I$(DRV_INCLUDES)
16
		-I$(DRV_INCLUDES)/uapi	\
-
 
17
		-I$(DRV_INCLUDES)/drm -I./ -I$(DRV_INCLUDES)
16
 
18
 
17
CFLAGS_OPT = -Os -march=i686 -fno-ident -fomit-frame-pointer -fno-builtin-printf -mno-ms-bitfields
19
CFLAGS_OPT = -Os -march=i686 -fno-ident -fomit-frame-pointer -fno-builtin-printf -mno-ms-bitfields
18
CFLAGS_OPT+= -mno-stack-arg-probe -mpreferred-stack-boundary=2 -mincoming-stack-boundary=2 -flto
20
CFLAGS_OPT+= -mno-stack-arg-probe -mpreferred-stack-boundary=2 -mincoming-stack-boundary=2 -flto
19
CFLAGS   = -c $(INCLUDES) $(DEFINES) $(CFLAGS_OPT)
21
CFLAGS   = -c $(INCLUDES) $(DEFINES) $(CFLAGS_OPT)
20
 
22
 
21
LIBPATH:= $(DDK_TOPDIR)
23
LIBPATH:= $(DDK_TOPDIR)
22
 
24
 
23
LIBS:= -lddk -lcore -lgcc 
25
LIBS:= -lddk -lcore -lgcc 
24
 
26
 
25
PE_FLAGS = --major-os-version,0,--minor-os-version,7,--major-subsystem-version,0,--minor-subsystem-version,5,--subsystem,native
27
PE_FLAGS = --major-os-version,0,--minor-os-version,7,--major-subsystem-version,0,--minor-subsystem-version,5,--subsystem,native
26
 
28
 
27
 
29
 
28
LDFLAGS = -nostdlib,-shared,-s,$(PE_FLAGS),--image-base,0,--file-alignment,512,--section-alignment,4096
30
LDFLAGS = -nostdlib,-shared,-s,$(PE_FLAGS),--image-base,0,--file-alignment,512,--section-alignment,4096
29
 
31
 
30
 
32
 
31
NAME:=	  atikms
33
NAME:=	  atikms
32
 
34
 
33
HFILES:=     		$(DRV_INCLUDES)/linux/types.h		\
35
HFILES:=     		$(DRV_INCLUDES)/linux/types.h		\
34
			$(DRV_INCLUDES)/linux/list.h		\
36
			$(DRV_INCLUDES)/linux/list.h		\
35
			$(DRV_INCLUDES)/linux/pci.h		\
37
			$(DRV_INCLUDES)/linux/pci.h		\
36
			$(DRV_INCLUDES)/drm/drm.h		\
38
			$(DRV_INCLUDES)/drm/drmP.h		\
37
			$(DRV_INCLUDES)/drm/drmP.h		\
-
 
38
			$(DRV_INCLUDES)/drm/drm_edid.h		\
39
			$(DRV_INCLUDES)/drm/drm_edid.h		\
39
			$(DRV_INCLUDES)/drm/drm_crtc.h		\
40
			$(DRV_INCLUDES)/drm/drm_crtc.h		\
40
			$(DRV_INCLUDES)/drm/drm_mm.h		\
41
			$(DRV_INCLUDES)/drm/drm_mm.h		\
41
			atom.h					\
42
			atom.h					\
42
			radeon.h				\
43
			radeon.h				\
43
			radeon_asic.h
44
			radeon_asic.h
44
 
45
 
45
NAME_SRC=							\
46
NAME_SRC=							\
46
			main.c					\
47
			main.c					\
47
			pci.c					\
48
			pci.c					\
48
			../ttm/ttm_bo.c				\
49
			../ttm/ttm_bo.c				\
49
			../ttm/ttm_bo_manager.c			\
50
			../ttm/ttm_bo_manager.c			\
50
			../ttm/ttm_bo_util.c			\
51
			../ttm/ttm_bo_util.c			\
51
			../ttm/ttm_execbuf_util.c		\
52
			../ttm/ttm_execbuf_util.c		\
52
			../ttm/ttm_memory.c			\
53
			../ttm/ttm_memory.c			\
53
			../ttm/ttm_page_alloc.c			\
54
			../ttm/ttm_page_alloc.c			\
54
			../ttm/ttm_tt.c				\
55
			../ttm/ttm_tt.c				\
55
			$(DRM_TOPDIR)/drm_cache.c		\
56
			$(DRM_TOPDIR)/drm_cache.c		\
56
			$(DRM_TOPDIR)/drm_crtc.c		\
57
			$(DRM_TOPDIR)/drm_crtc.c		\
57
			$(DRM_TOPDIR)/drm_crtc_helper.c		\
58
			$(DRM_TOPDIR)/drm_crtc_helper.c		\
58
			$(DRM_TOPDIR)/drm_dp_helper.c		\
59
			$(DRM_TOPDIR)/drm_dp_helper.c		\
59
			$(DRM_TOPDIR)/drm_drv.c			\
60
			$(DRM_TOPDIR)/drm_drv.c			\
60
			$(DRM_TOPDIR)/drm_edid.c		\
61
			$(DRM_TOPDIR)/drm_atomic.c		\
-
 
62
			$(DRM_TOPDIR)/drm_edid.c		\
61
			$(DRM_TOPDIR)/drm_fb_helper.c		\
63
			$(DRM_TOPDIR)/drm_fb_helper.c		\
62
			$(DRM_TOPDIR)/drm_gem.c			\
64
			$(DRM_TOPDIR)/drm_gem.c			\
63
			$(DRM_TOPDIR)/drm_global.c		\
65
			$(DRM_TOPDIR)/drm_global.c		\
64
			$(DRM_TOPDIR)/drm_irq.c			\
66
			$(DRM_TOPDIR)/drm_irq.c			\
65
			$(DRM_TOPDIR)/drm_mm.c			\
67
			$(DRM_TOPDIR)/drm_mm.c			\
66
			$(DRM_TOPDIR)/drm_modes.c		\
68
			$(DRM_TOPDIR)/drm_modes.c		\
67
			$(DRM_TOPDIR)/drm_modeset_lock.c	\
69
			$(DRM_TOPDIR)/drm_modeset_lock.c	\
68
			$(DRM_TOPDIR)/drm_pci.c			\
70
			$(DRM_TOPDIR)/drm_pci.c			\
69
			$(DRM_TOPDIR)/drm_plane_helper.c	\
71
			$(DRM_TOPDIR)/drm_plane_helper.c	\
70
			$(DRM_TOPDIR)/drm_probe_helper.c	\
72
			$(DRM_TOPDIR)/drm_probe_helper.c	\
71
			$(DRM_TOPDIR)/drm_rect.c		\
73
			$(DRM_TOPDIR)/drm_rect.c		\
72
			$(DRM_TOPDIR)/drm_stub.c		\
74
			$(DRM_TOPDIR)/drm_stub.c		\
73
			$(DRM_TOPDIR)/drm_vma_manager.c		\
75
			$(DRM_TOPDIR)/drm_vma_manager.c		\
74
			$(DRM_TOPDIR)/i2c/i2c-core.c		\
76
			$(DRM_TOPDIR)/i2c/i2c-core.c		\
75
			$(DRM_TOPDIR)/i2c/i2c-algo-bit.c	\
77
			$(DRM_TOPDIR)/i2c/i2c-algo-bit.c	\
76
			hmm.c					\
78
			hmm.c					\
77
			radeon_device.c				\
79
			radeon_device.c				\
78
			atom.c					\
80
			atom.c					\
79
			atombios_crtc.c				\
81
			atombios_crtc.c				\
80
			atombios_dp.c				\
82
			atombios_dp.c				\
81
			atombios_encoders.c			\
83
			atombios_encoders.c			\
82
			atombios_i2c.c				\
84
			atombios_i2c.c				\
83
			btc_dpm.c				\
85
			btc_dpm.c				\
84
			cayman_blit_shaders.c			\
86
			cayman_blit_shaders.c			\
85
			ci_dpm.c				\
87
			ci_dpm.c				\
86
			ci_smc.c				\
88
			ci_smc.c				\
87
			cik.c					\
89
			cik.c					\
88
			cik_blit_shaders.c			\
90
			cik_blit_shaders.c			\
89
			cik_sdma.c				\
91
			cik_sdma.c				\
90
			cypress_dpm.c				\
92
			cypress_dpm.c				\
91
			dce3_1_afmt.c				\
93
			dce3_1_afmt.c				\
92
			dce6_afmt.c				\
94
			dce6_afmt.c				\
93
			evergreen.c				\
95
			evergreen.c				\
94
			evergreen_blit_shaders.c		\
96
			evergreen_blit_shaders.c		\
95
			evergreen_cs.c				\
97
			evergreen_cs.c				\
96
			evergreen_dma.c				\
98
			evergreen_dma.c				\
97
			evergreen_hdmi.c			\
99
			evergreen_hdmi.c			\
98
			kv_dpm.c				\
100
			kv_dpm.c				\
99
			kv_smc.c				\
101
			kv_smc.c				\
100
			ni.c					\
102
			ni.c					\
101
			ni_dma.c				\
103
			ni_dma.c				\
102
			ni_dpm.c				\
104
			ni_dpm.c				\
103
			radeon_agp.c				\
105
			radeon_agp.c				\
104
			radeon_asic.c				\
106
			radeon_asic.c				\
105
			radeon_atombios.c			\
107
			radeon_atombios.c			\
106
			radeon_benchmark.c			\
108
			radeon_benchmark.c			\
107
			radeon_bios.c				\
109
			radeon_bios.c				\
108
			radeon_combios.c			\
110
			radeon_combios.c			\
109
			radeon_connectors.c			\
111
			radeon_connectors.c			\
110
			radeon_cs.c				\
112
			radeon_cs.c				\
111
			radeon_clocks.c				\
113
			radeon_clocks.c				\
112
			radeon_display.c			\
114
			radeon_display.c			\
113
			radeon_encoders.c			\
115
			radeon_encoders.c			\
114
			radeon_fence.c				\
116
			radeon_fence.c				\
115
			radeon_fb.c				\
117
			radeon_fb.c				\
116
			radeon_gart.c				\
118
			radeon_gart.c				\
117
			radeon_gem.c				\
119
			radeon_gem.c				\
118
			radeon_i2c.c				\
120
			radeon_i2c.c				\
119
			radeon_ib.c				\
121
			radeon_ib.c				\
120
			radeon_irq_kms.c			\
122
			radeon_irq_kms.c			\
121
			radeon_legacy_crtc.c			\
123
			radeon_legacy_crtc.c			\
122
			radeon_legacy_encoders.c		\
124
			radeon_legacy_encoders.c		\
123
			radeon_legacy_tv.c			\
125
			radeon_legacy_tv.c			\
124
			radeon_object.c				\
126
			radeon_object.c				\
125
			radeon_pm.c				\
127
			radeon_pm.c				\
126
			radeon_ring.c				\
128
			radeon_ring.c				\
127
			radeon_sa.c				\
129
			radeon_sa.c				\
128
			radeon_semaphore.c			\
130
			radeon_semaphore.c			\
129
			radeon_test.c				\
131
			radeon_sync.c				\
-
 
132
			radeon_test.c				\
130
			radeon_ttm.c				\
133
			radeon_ttm.c				\
131
			radeon_ucode.c				\
134
			radeon_ucode.c				\
132
			radeon_uvd.c				\
135
			radeon_uvd.c				\
133
			radeon_vce.c				\
136
			radeon_vce.c				\
134
			radeon_vm.c				\
137
			radeon_vm.c				\
135
			rdisplay_kms.c				\
138
			rdisplay_kms.c				\
136
			r100.c					\
139
			r100.c					\
137
			r200.c					\
140
			r200.c					\
138
			r300.c					\
141
			r300.c					\
139
			r420.c					\
142
			r420.c					\
140
			rv515.c					\
143
			rv515.c					\
141
			rv730_dpm.c				\
144
			rv730_dpm.c				\
142
			rv740_dpm.c				\
145
			rv740_dpm.c				\
143
			r520.c					\
146
			r520.c					\
144
			r600.c					\
147
			r600.c					\
145
			r600_audio.c				\
148
			r600_blit_shaders.c			\
146
			r600_blit_shaders.c			\
-
 
147
			r600_cs.c				\
149
			r600_cs.c				\
148
			r600_dma.c				\
150
			r600_dma.c				\
149
			r600_dpm.c				\
151
			r600_dpm.c				\
150
			r600_hdmi.c				\
152
			r600_hdmi.c				\
151
			rs400.c					\
153
			rs400.c					\
152
			rs600.c					\
154
			rs600.c					\
153
			rs690.c					\
155
			rs690.c					\
154
			rv6xx_dpm.c				\
156
			rv6xx_dpm.c				\
155
			rs780_dpm.c				\
157
			rs780_dpm.c				\
156
			rv770.c					\
158
			rv770.c					\
157
			rv770_dma.c				\
159
			rv770_dma.c				\
158
			rv770_dpm.c				\
160
			rv770_dpm.c				\
159
			rv770_smc.c				\
161
			rv770_smc.c				\
160
			rdisplay.c				\
162
			rdisplay.c				\
161
			cmdline.c				\
163
			cmdline.c				\
162
			si.c					\
164
			si.c					\
163
			si_blit_shaders.c			\
165
			si_blit_shaders.c			\
164
			si_dma.c				\
166
			si_dma.c				\
165
			si_dpm.c				\
167
			si_dpm.c				\
166
			si_smc.c				\
168
			si_smc.c				\
167
			sumo_dpm.c				\
169
			sumo_dpm.c				\
168
			sumo_smc.c				\
170
			sumo_smc.c				\
169
			trinity_dpm.c				\
171
			trinity_dpm.c				\
170
			trinity_smc.c				\
172
			trinity_smc.c				\
171
			utils.c					\
173
			utils.c					\
172
			uvd_v1_0.c				\
174
			uvd_v1_0.c				\
173
			uvd_v2_2.c				\
175
			uvd_v2_2.c				\
174
			uvd_v3_1.c				\
176
			uvd_v3_1.c				\
175
			uvd_v4_2.c				\
177
			uvd_v4_2.c				\
176
			vce_v1_0.c				\
178
			vce_v1_0.c				\
177
			vce_v2_0.c				\
179
			vce_v2_0.c				\
178
			fwblob.asm
180
			fwblob.asm
179
 
181
 
180
FW_BINS=							\
182
FW_BINS=							\
181
			firmware/R100_cp.bin			\
183
			firmware/R100_cp.bin			\
182
			firmware/R200_cp.bin			\
184
			firmware/R200_cp.bin			\
183
			firmware/R300_cp.bin			\
185
			firmware/R300_cp.bin			\
184
			firmware/R420_cp.bin			\
186
			firmware/R420_cp.bin			\
185
			firmware/R520_cp.bin			\
187
			firmware/R520_cp.bin			\
186
								\
188
								\
187
			firmware/RS690_cp.bin			\
189
			firmware/RS690_cp.bin			\
188
			firmware/RS600_cp.bin			\
190
			firmware/RS600_cp.bin			\
189
			firmware/RS780_me.bin			\
191
			firmware/RS780_me.bin			\
190
			firmware/RS780_pfp.bin			\
192
			firmware/RS780_pfp.bin			\
191
								\
193
								\
192
			firmware/RV610_me.bin			\
194
			firmware/RV610_me.bin			\
193
			firmware/RV620_me.bin			\
195
			firmware/RV620_me.bin			\
194
			firmware/RV630_me.bin			\
196
			firmware/RV630_me.bin			\
195
			firmware/RV635_me.bin			\
197
			firmware/RV635_me.bin			\
196
			firmware/RV670_me.bin			\
198
			firmware/RV670_me.bin			\
197
			firmware/RV710_me.bin			\
199
			firmware/RV710_me.bin			\
198
			firmware/RV730_me.bin			\
200
			firmware/RV730_me.bin			\
199
			firmware/RV770_me.bin			\
201
			firmware/RV770_me.bin			\
200
								\
202
								\
201
			firmware/RV610_pfp.bin			\
203
			firmware/RV610_pfp.bin			\
202
			firmware/RV620_pfp.bin			\
204
			firmware/RV620_pfp.bin			\
203
			firmware/RV630_pfp.bin			\
205
			firmware/RV630_pfp.bin			\
204
			firmware/RV635_pfp.bin			\
206
			firmware/RV635_pfp.bin			\
205
			firmware/RV670_pfp.bin			\
207
			firmware/RV670_pfp.bin			\
206
			firmware/RV710_pfp.bin			\
208
			firmware/RV710_pfp.bin			\
207
			firmware/RV730_pfp.bin			\
209
			firmware/RV730_pfp.bin			\
208
			firmware/RV770_pfp.bin			\
210
			firmware/RV770_pfp.bin			\
209
								\
211
								\
210
			firmware/R600_rlc.bin			\
212
			firmware/R600_rlc.bin			\
211
			firmware/R700_rlc.bin
213
			firmware/R700_rlc.bin
212
 
214
 
213
 
215
 
214
SRC_DEP:=    
216
SRC_DEP:=    
215
 
217
 
216
 
218
 
217
NAME_OBJS =  $(patsubst %.S, %.o, $(patsubst %.asm, %.o,\
219
NAME_OBJS =  $(patsubst %.S, %.o, $(patsubst %.asm, %.o,\
218
            $(patsubst %.c, %.o, $(NAME_SRC))))
220
            $(patsubst %.c, %.o, $(NAME_SRC))))
219
 
221
 
220
 
222
 
221
 
223
 
222
all: $(NAME).dll
224
all: $(NAME).dll
223
 
225
 
224
$(NAME).dll: $(NAME_OBJS) $(FW_BINS) $(SRC_DEP) $(HFILES) $(LIBPATH)/libcore.a $(LIBPATH)/libddk.a atikms.lds Makefile.lto
226
$(NAME).dll: $(NAME_OBJS) $(FW_BINS) $(SRC_DEP) $(HFILES) $(LIBPATH)/libcore.a $(LIBPATH)/libddk.a atikms.lds Makefile.lto
225
	$(CC) $(CFLAGS_OPT) -fwhole-program -nostdlib -Wl,-L$(LIBPATH),$(LDFLAGS),-T,atikms.lds -o $@ $(NAME_OBJS) $(LIBS)
227
	$(CC) $(CFLAGS_OPT) -fwhole-program -nostdlib -Wl,-L$(LIBPATH),$(LDFLAGS),-T,atikms.lds -o $@ $(NAME_OBJS) $(LIBS)
226
 
228
 
227
 
229
 
228
%.o : %.c $(HFILES) Makefile.lto
230
%.o : %.c $(HFILES) Makefile.lto
229
	$(CC) $(CFLAGS) -o $@ $<
231
	$(CC) $(CFLAGS) -o $@ $<
230
 
232
 
231
%.o : %.S $(HFILES) Makefile.lto
233
%.o : %.S $(HFILES) Makefile.lto
232
	$(AS) -o $@ $<
234
	$(AS) -o $@ $<
233
 
235
 
234
fwblob.o:  fwblob.asm $(FW_BINS) Makefile.lto
236
fwblob.o:  fwblob.asm $(FW_BINS) Makefile.lto
235
	$(FASM) $< $@
237
	$(FASM) $< $@
236
 
238
 
237
fwblob.o:>
239
fwblob.o:>
238
 
240
 
239
%.o>
241
%.o>