Subversion Repositories Kolibri OS

Rev

Rev 5271 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

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