Hilfe wie füge ich Module ein

  • 40 Antworten
  • Letztes Antwortdatum
taffeljunge

taffeljunge

Erfahrenes Mitglied
17
Hallo wollte gerne wissen wie ich z. B. Rtl8187.ko in einem Kernel einpflege.

Gesendet von meinem GT-I9300 mit Tapatalk 2
 
Zuletzt bearbeitet:
Sourcen des Moduls gegen die Kernel sourcen kompilieren.
 
ok danke und für anfänger also ich benutze den siyah 1.8.9 und möchte folgenede module hinzufügen eeprom_93cx6.ko ,mac80211.ko, rtl8187.ko wie stelle ich das an kann man das vom handy machen oder vom pc.
 
Für Anfänger ist das nicht zu empfehlen..
 
Ich brauch nur noch paar kleine Infos den Kernel Quellcode von meinem jetzigen Kernel habe ich toolchain auch aber wie geht's es weiter kann ich die vorhanden Module benutzen oder brauch ich da auch ne Art Quellcode von
 
Wenn ich die Module laden will bekommen ich folgenden Fehler

Ich denke mal weil das Modul für einen anderen Kernel bestimmt ist
 

Anhänge

  • uploadfromtaptalk1361733543622.jpg
    uploadfromtaptalk1361733543622.jpg
    62,4 KB · Aufrufe: 339
Ich hätte noch ein paar ergänzende Hinweise:

  • Es wäre hilfreich, wenn Du die Configuration Deines Kernel hättest. Wenn Du Glück hast, ist sie unter /proc/config.gz auf dem Händy zu finden.
  • Wenn Du die Config dort gefunden hast, entpacken und ins Basisverzeichnis der Kernelsourcen als .config legen
  • Zunächst mal versuchen den Kernel wie er ist zu kompilieren. Erst wenn da keine Probleme mehr bestehen, an zusätzliche Sourcen ranwagen.
  • Am besten jedes Modul einzeln zum Kernel zufügen, erst wenn eines geklappt hat, ans nächste gehen.
  • Um ein Modul zuzufügen, die Sourcen in ein geeignetes Unterverzeichnis der Kernelsourcen reinlegen, inclusive der zugehörigen Header Files (.h).
  • Wenn Du ein file xyz.c in ein Verzeichnis zugefügt hast, in diesem Verzeichnis das MAKEFILE öffnen und als letzte Zeile zufügen: obj-y += xyz.o. Das baut das Modul erst mal fest in den Kernel ein. wenn das klappt, kannst Du obj-y durch obj-m ersetzen, um ein nachladbares Modul zu erzeugen. Später kann man sich darum kümmern, diese Einstellung so zu machen, dass es im Menuconfig Wählbar ist.
  • Zum Schluss mustt Du noch lernen, wie Du aus dem beim build erzeugten zImage ein Boot-Image machst. Dazu gibt es die Tools mkbootimg und unpackbootimg. Wenn Du ein zImage erzeugen konntest, sag Bescheid, dann sprechen wir über den Rest...

Grüsse Uwe
 
Zuletzt bearbeitet von einem Moderator:
  • Danke
Reaktionen: taffeljunge
Ok Danke ich werde es heute nachmittag versuchen. Ich sag Bescheid ob es geklappt hat
 
in welchen ordner muss ich die module reinpacken um sie yu erstellen
 
Spielt im Prinzip keine Rolle. Muss halt im Sourcetree sein, unter drivers z.b. da gibt es auch Unterordner. Den Eintrag dann im Makefile des Ordner vornehmen, indem die Module sind

Grüsse Uwe
 
folgene fehler meldung bekomme ich beim kernel erstellen
make: arm-linux-gnueabi-gcc: Command not found
scripts/kconfig/conf --silentoldconfig Kconfig
drivers/media/video/samsung/mali/Kconfig:18:warning: choice value used outside its choice group
drivers/media/video/samsung/mali/Kconfig:22:warning: choice value used outside its choice group
drivers/media/video/samsung/mali/Kconfig:26:warning: choice value used outside its choice group
drivers/media/video/samsung/mali/Kconfig:30:warning: choice value used outside its choice group
make: arm-linux-gnueabi-gcc: Command not found
CHK include/linux/version.h
CHK include/generated/utsrelease.h
Generating include/generated/mach-types.h
CC kernel/bounds.s
/bin/sh: arm-linux-gnueabi-gcc: command not found
make[1]: *** [kernel/bounds.s] Error 127
make: *** [prepare0] Error 2
 
Beim build ist immer der erste Fehler entscheident. das war bei Dir das:
make : arm-linux-gnueabi.gcc not found.

Entweder den Pfad zum Tool in den Pat aufnehmen oder absolut addressieren.

wenn Dein tool unter /opt/gcc läge:

Code:
export PATH=$PATH:/opt/gcc

oder dort wo Du arm-linux... configurierts /opt/gcc/arm-linux... verwenden

Grüsse Uwe
 
  • Danke
Reaktionen: taffeljunge
Ok das war genau das sehr hilfreich.
Eine Frage noch ich habe jetzt die Rtl8187 Module im Rtl818X Ordner da habe ich die Header Files und mit ENDUNG .0 DRINNE mit welchen Befehl werden daraus .ko Datein oder geschieht das automatisch beim erstellen des kernels
 
Wenn Du eine Sourcedatei hast die rtl8187.c heisst, die in einem bereits vorhandenen Ordner
Deiner Kernel sourcen platziert wird, (erst mal keinen eigenen Order anlegen!) und dort im vorhandenen Makefile obj-y+=rtl8187.o (Andere Endung beachten!) einträgst, dann wird das Modul gebaut und direkt in den Kernel integriert. Wenn das geklappt hat, aus obj-y einfach obj-m machen, und erneut build aufrufen, dann wird das Modul nicht in den Kernel eingebaut, sondern ein rtl8187.ko erzeugt.

Grüsse Uwe
 
rene@rene-Aspire-X5950://home/rene/Arbeitsfläche/Kernel$ make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- -j3
CHK include/linux/version.h
CHK include/generated/utsrelease.h
make[1]: »include/generated/mach-types.h« ist bereits aktualisiert.
CC arch/arm/kernel/asm-offsets.s
In file included from arch/arm/kernel/asm-offsets.c:16:0:
/home/rene/Arbeitsfläche/Kernel/arch/arm/include/asm/cacheflush.h:19:22: Schwerwiegender Fehler: mach/smc.h: Datei oder Verzeichnis nicht gefunden
Kompilierung beendet.
make[1]: *** [arch/arm/kernel/asm-offsets.s] Fehler 1
make: *** [prepare0] Fehler 2
rene@rene-Aspire-X5950://home/rene/Arbeitsfläche/Kernel$


was ist da schon wieder schief gelauffen
 
Ist das ein Build mit oder ohne zusätzliche Module?

Kannst Du die Datei arch/arm/include asm/cacheflush.h mal posten?

Hast Du die config von Deinem Device nach /home/rene/Arbeitsfläche/Kernel gelegt? (Als .config)

Grüsse Uwe
 
das bild ist ohne module und ja ich habe die config von meinem handy.
So hier ist die datei
*
* arch/arm/include/asm/cacheflush.h
*
* Copyright (C) 1999-2002 Russell King
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#ifndef _ASMARM_CACHEFLUSH_H
#define _ASMARM_CACHEFLUSH_H

#include <linux/mm.h>

#include <asm/glue-cache.h>
#include <asm/shmparam.h>
#include <asm/cachetype.h>
#include <asm/outercache.h>
#include <mach/smc.h>

#define CACHE_COLOUR(vaddr) ((vaddr & (SHMLBA - 1)) >> PAGE_SHIFT)

/*
* This flag is used to indicate that the page pointed to by a pte is clean
* and does not require cleaning before returning it to the user.
*/
#define PG_dcache_clean PG_arch_1

/*
* MM Cache Management
* ===================
*
* The arch/arm/mm/cache-*.S and arch/arm/mm/proc-*.S files
* implement these methods.
*
* Start addresses are inclusive and end addresses are exclusive;
* start addresses should be rounded down, end addresses up.
*
* See Documentation/cachetlb.txt for more information.
* Please note that the implementation of these, and the required
* effects are cache-type (VIVT/VIPT/PIPT) specific.
*
* flush_icache_all()
*
* Unconditionally clean and invalidate the entire icache.
* Currently only needed for cache-v6.S and cache-v7.S, see
* __flush_icache_all for the generic implementation.
*
* flush_kern_all()
*
* Unconditionally clean and invalidate the entire cache.
*
* flush_user_all()
*
* Clean and invalidate all user space cache entries
* before a change of page tables.
*
* flush_user_range(start, end, flags)
*
* Clean and invalidate a range of cache entries in the
* specified address space before a change of page tables.
* - start - user start address (inclusive, page aligned)
* - end - user end address (exclusive, page aligned)
* - flags - vma->vm_flags field
*
* coherent_kern_range(start, end)
*
* Ensure coherency between the Icache and the Dcache in the
* region described by start, end. If you have non-snooping
* Harvard caches, you need to implement this function.
* - start - virtual start address
* - end - virtual end address
*
* coherent_user_range(start, end)
*
* Ensure coherency between the Icache and the Dcache in the
* region described by start, end. If you have non-snooping
* Harvard caches, you need to implement this function.
* - start - virtual start address
* - end - virtual end address
*
* flush_kern_dcache_area(kaddr, size)
*
* Ensure that the data held in page is written back.
* - kaddr - page address
* - size - region size
*
* DMA Cache Coherency
* ===================
*
* dma_flush_range(start, end)
*
* Clean and invalidate the specified virtual address range.
* - start - virtual start address
* - end - virtual end address
*/

struct cpu_cache_fns {
void (*flush_icache_all)(void);
void (*flush_kern_all)(void);
void (*flush_user_all)(void);
void (*flush_user_range)(unsigned long, unsigned long, unsigned int);

void (*coherent_kern_range)(unsigned long, unsigned long);
void (*coherent_user_range)(unsigned long, unsigned long);
void (*flush_kern_dcache_area)(void *, size_t);

void (*dma_map_area)(const void *, size_t, int);
void (*dma_unmap_area)(const void *, size_t, int);

void (*dma_flush_range)(const void *, const void *);
};

/*
* Select the calling method
*/
#ifdef MULTI_CACHE

extern struct cpu_cache_fns cpu_cache;

#define __cpuc_flush_icache_all cpu_cache.flush_icache_all
#define __cpuc_flush_kern_all cpu_cache.flush_kern_all
#define __cpuc_flush_user_all cpu_cache.flush_user_all
#define __cpuc_flush_user_range cpu_cache.flush_user_range
#define __cpuc_coherent_kern_range cpu_cache.coherent_kern_range
#define __cpuc_coherent_user_range cpu_cache.coherent_user_range
#define __cpuc_flush_dcache_area cpu_cache.flush_kern_dcache_area

/*
* These are private to the dma-mapping API. Do not use directly.
* Their sole purpose is to ensure that data held in the cache
* is visible to DMA, or data written by DMA to system memory is
* visible to the CPU.
*/
#define dmac_map_area cpu_cache.dma_map_area
#define dmac_unmap_area cpu_cache.dma_unmap_area
#define dmac_flush_range cpu_cache.dma_flush_range

#else

extern void __cpuc_flush_icache_all(void);
extern void __cpuc_flush_kern_all(void);
extern void __cpuc_flush_user_all(void);
extern void __cpuc_flush_user_range(unsigned long, unsigned long, unsigned int);
extern void __cpuc_coherent_kern_range(unsigned long, unsigned long);
extern void __cpuc_coherent_user_range(unsigned long, unsigned long);
extern void __cpuc_flush_dcache_area(void *, size_t);

/*
* These are private to the dma-mapping API. Do not use directly.
* Their sole purpose is to ensure that data held in the cache
* is visible to DMA, or data written by DMA to system memory is
* visible to the CPU.
*/
extern void dmac_map_area(const void *, size_t, int);
extern void dmac_unmap_area(const void *, size_t, int);
extern void dmac_flush_range(const void *, const void *);

#endif

/*
* Copy user data from/to a page which is mapped into a different
* processes address space. Really, we want to allow our "user
* space" model to handle this.
*/
extern void copy_to_user_page(struct vm_area_struct *, struct page *,
unsigned long, void *, const void *, unsigned long);
#define copy_from_user_page(vma, page, vaddr, dst, src, len) \
do { \
memcpy(dst, src, len); \
} while (0)

/*
* Convert calls to our calling convention.
*/

/* Invalidate I-cache */
#define __flush_icache_all_generic() \
asm("mcr p15, 0, %0, c7, c5, 0" \
: : "r" (0));

/* Invalidate I-cache inner shareable */
#define __flush_icache_all_v7_smp() \
asm("mcr p15, 0, %0, c7, c1, 0" \
: : "r" (0));

/*
* Optimized __flush_icache_all for the common cases. Note that UP ARMv7
* will fall through to use __flush_icache_all_generic.
*/
#if (defined(CONFIG_CPU_V7) && \
(defined(CONFIG_CPU_V6) || defined(CONFIG_CPU_V6K))) || \
defined(CONFIG_SMP_ON_UP)
#define __flush_icache_preferred __cpuc_flush_icache_all
#elif __LINUX_ARM_ARCH__ >= 7 && defined(CONFIG_SMP)
#define __flush_icache_preferred __flush_icache_all_v7_smp
#elif __LINUX_ARM_ARCH__ == 6 && defined(CONFIG_ARM_ERRATA_411920)
#define __flush_icache_preferred __cpuc_flush_icache_all
#else
#define __flush_icache_preferred __flush_icache_all_generic
#endif

static inline void __flush_icache_all(void)
{
__flush_icache_preferred();
}

#define flush_cache_all() __cpuc_flush_kern_all()

#ifndef CONFIG_SMP
#define flush_all_cpu_caches() flush_cache_all()
#else
extern void flush_all_cpu_caches(void);
#endif

static inline void vivt_flush_cache_mm(struct mm_struct *mm)
{
if (cpumask_test_cpu(smp_processor_id(), mm_cpumask(mm)))
__cpuc_flush_user_all();
}

static inline void
vivt_flush_cache_range(struct vm_area_struct *vma, unsigned long start, unsigned long end)
{
if (cpumask_test_cpu(smp_processor_id(), mm_cpumask(vma->vm_mm)))
__cpuc_flush_user_range(start & PAGE_MASK, PAGE_ALIGN(end),
vma->vm_flags);
}

static inline void
vivt_flush_cache_page(struct vm_area_struct *vma, unsigned long user_addr, unsigned long pfn)
{
if (cpumask_test_cpu(smp_processor_id(), mm_cpumask(vma->vm_mm))) {
unsigned long addr = user_addr & PAGE_MASK;
__cpuc_flush_user_range(addr, addr + PAGE_SIZE, vma->vm_flags);
}
}

#ifndef CONFIG_CPU_CACHE_VIPT
#define flush_cache_mm(mm) \
vivt_flush_cache_mm(mm)
#define flush_cache_range(vma,start,end) \
vivt_flush_cache_range(vma,start,end)
#define flush_cache_page(vma,addr,pfn) \
vivt_flush_cache_page(vma,addr,pfn)
#else
extern void flush_cache_mm(struct mm_struct *mm);
extern void flush_cache_range(struct vm_area_struct *vma, unsigned long start, unsigned long end);
extern void flush_cache_page(struct vm_area_struct *vma, unsigned long user_addr, unsigned long pfn);
#endif

#define flush_cache_dup_mm(mm) flush_cache_mm(mm)

/*
* flush_cache_user_range is used when we want to ensure that the
* Harvard caches are synchronised for the user space address range.
* This is used for the ARM private sys_cacheflush system call.
*/
#define flush_cache_user_range(start,end) \
__cpuc_coherent_user_range((start) & PAGE_MASK, PAGE_ALIGN(end))

/*
* Perform necessary cache operations to ensure that data previously
* stored within this range of addresses can be executed by the CPU.
*/
#define flush_icache_range(s,e) __cpuc_coherent_kern_range(s,e)

/*
* Perform necessary cache operations to ensure that the TLB will
* see data written in the specified area.
*/
#define clean_dcache_area(start,size) cpu_dcache_clean_area(start, size)

/*
* flush_dcache_page is used when the kernel has written to the page
* cache page at virtual address page->virtual.
*
* If this page isn't mapped (ie, page_mapping == NULL), or it might
* have userspace mappings, then we _must_ always clean + invalidate
* the dcache entries associated with the kernel mapping.
*
* Otherwise we can defer the operation, and clean the cache when we are
* about to change to user space. This is the same method as used on SPARC64.
* See update_mmu_cache for the user space part.
*/
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1
extern void flush_dcache_page(struct page *);

static inline void flush_kernel_vmap_range(void *addr, int size)
{
if ((cache_is_vivt() || cache_is_vipt_aliasing()))
__cpuc_flush_dcache_area(addr, (size_t)size);
}
static inline void invalidate_kernel_vmap_range(void *addr, int size)
{
if ((cache_is_vivt() || cache_is_vipt_aliasing()))
__cpuc_flush_dcache_area(addr, (size_t)size);
}

#define ARCH_HAS_FLUSH_ANON_PAGE
static inline void flush_anon_page(struct vm_area_struct *vma,
struct page *page, unsigned long vmaddr)
{
extern void __flush_anon_page(struct vm_area_struct *vma,
struct page *, unsigned long);
if (PageAnon(page))
__flush_anon_page(vma, page, vmaddr);
}

#define ARCH_HAS_FLUSH_KERNEL_DCACHE_PAGE
static inline void flush_kernel_dcache_page(struct page *page)
{
}

#define flush_dcache_mmap_lock(mapping) \
spin_lock_irq(&(mapping)->tree_lock)
#define flush_dcache_mmap_unlock(mapping) \
spin_unlock_irq(&(mapping)->tree_lock)

#define flush_icache_user_range(vma,page,addr,len) \
flush_dcache_page(page)

/*
* We don't appear to need to do anything here. In fact, if we did, we'd
* duplicate cache flushing elsewhere performed by flush_dcache_page().
*/
#define flush_icache_page(vma,page) do { } while (0)

/*
* flush_cache_vmap() is used when creating mappings (eg, via vmap,
* vmalloc, ioremap etc) in kernel space for pages. On non-VIPT
* caches, since the direct-mappings of these pages may contain cached
* data, we need to do a full cache flush to ensure that writebacks
* don't corrupt data placed into these pages via the new mappings.
*/
static inline void flush_cache_vmap(unsigned long start, unsigned long end)
{
if (!cache_is_vipt_nonaliasing())
flush_cache_all();
else
/*
* set_pte_at() called from vmap_pte_range() does not
* have a DSB after cleaning the cache line.
*/
dsb();
}

static inline void flush_cache_vunmap(unsigned long start, unsigned long end)
{
if (!cache_is_vipt_nonaliasing())
flush_cache_all();
}

/*
* Control the full line of zero function that must be enabled
* only when the slaves connected on cortex-A9 AXI master port support it.
* The L2-310 cache controller supports this feature.
*/
#ifdef CONFIG_CACHE_L2X0
static inline void __enable_cache_foz(int enable)
{
int val;

asm volatile(
"mrc p15, 0, %0, c1, c0, 1\n"
: "=r" (val));

/* enable/disable Foz */
if (enable)
val |= ((1<<3));
else
val &= (~(1<<3));

#ifdef CONFIG_ARM_TRUSTZONE
exynos_smc(SMC_CMD_REG, SMC_REG_ID_CP15(1, 0, 0, 1), val, 0);
#else
asm volatile("mcr p15, 0, %0, c1, c0, 1" : : "r" (val));
#endif
}

#define enable_cache_foz() __enable_cache_foz(1)
#define disable_cache_foz() __enable_cache_foz(0)
#else
#define enable_cache_foz() do { } while (0)
#define disable_cache_foz() do { } while (0)
#endif
#endif
 
Verzeiht, aber ich frage mich: "Was macht ihr da?"

Ich gehe mal davon aus, es ist ein 3er Kernel. Da ist der rtl8187 Treiber schon mit im Quellcode deines Kernels enthalten. Du brauchst keinen externen Quellcode deinem Kernel hinzufügen.

Nimm die config von /proc/config.gz von deinem Gerät. Entpacke, ins Verzeichnis deines Kernels kopiern und in .config umbenennen.
Danche im Terminal
Code:
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- menuconfig
Dort suchst du dann den richtige Einstellung, müsste irgendwo unter drivers->Networking sein. Machst beim Menueintrag für rtl8187 ein M und kompilierst das ganze. Das Modul kannst du dann auf dein gerät kompilieren und mit insmod laden.
 
Dann probiere mal folgendes

Wenn Du im Verzeichnis ~/Arbeitsfläche/Kernel bist
Code:
cp .config config_bac
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- distclean
cp config_bac .config
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- menuconfig

Dann erscheint ein Konfig-Fenster in der Konsole
Das kannst Du verlassen, aber speichere die Konfig, auch wenn Du nichts geändert hast! (Du hast vor dem clean mit 'cp .config config_bac' ein backup erstellt, also keine Sorge!

Und dann nochmal probieren:

Code:
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabi- -j3

Grüsse Uwe

Der ursprüngliche Beitrag von 22:32 Uhr wurde um 22:35 Uhr ergänzt:

perpe schrieb:
Verzeiht, aber ich frage mich: "Was macht ihr da?"

Ich gehe mal davon aus, es ist ein 3er Kernel. Da ist der rtl8187 Treiber schon mit im Quellcode deines Kernels enthalten. Du brauchst keinen externen Quellcode deinem Kernel hinzufügen.
.

Nach Aussage des TO ist das ein Build noch ohne Module, also funktioniert das Build-Environment noch nicht ganz. Die config läge schon als .config im Basisverzeichnis des Kernels.

Grüsse Uwe
 
  • Danke
Reaktionen: taffeljunge

Ähnliche Themen

M
  • mikesch dauerhaft
Antworten
12
Aufrufe
2.603
BOotnoOB
BOotnoOB
Foh
Antworten
8
Aufrufe
1.886
Foh
Foh
cehuisken
Antworten
1
Aufrufe
899
Andy
Andy
Zurück
Oben Unten