x86/geos: redux of cs5535 version
[openwrt.git] / target / linux / lantiq / patches / 809-mt-vpe.patch
index 07312c7..ea50761 100644 (file)
@@ -1,6 +1,6 @@
 --- a/arch/mips/Kconfig
 +++ b/arch/mips/Kconfig
 --- a/arch/mips/Kconfig
 +++ b/arch/mips/Kconfig
-@@ -1669,6 +1669,28 @@ config MIPS_VPE_LOADER
+@@ -1837,6 +1837,28 @@ config MIPS_VPE_LOADER
          Includes a loader for loading an elf relocatable object
          onto another VPE and running it.
  
          Includes a loader for loading an elf relocatable object
          onto another VPE and running it.
  
  #define read_tc_gpr_sp()              mftgpr(29)
 --- a/arch/mips/kernel/Makefile
 +++ b/arch/mips/kernel/Makefile
  #define read_tc_gpr_sp()              mftgpr(29)
 --- a/arch/mips/kernel/Makefile
 +++ b/arch/mips/kernel/Makefile
-@@ -84,7 +84,8 @@ obj-$(CONFIG_MIPS32_O32)     += binfmt_elfo3
+@@ -85,7 +85,8 @@ obj-$(CONFIG_MIPS32_O32)     += binfmt_elfo3
  
  obj-$(CONFIG_KGDB)            += kgdb.o
  obj-$(CONFIG_PROC_FS)         += proc.o
  
  obj-$(CONFIG_KGDB)            += kgdb.o
  obj-$(CONFIG_PROC_FS)         += proc.o
  obj-$(CONFIG_I8253)           += i8253.o
 --- a/arch/mips/kernel/mips-mt.c
 +++ b/arch/mips/kernel/mips-mt.c
  obj-$(CONFIG_I8253)           += i8253.o
 --- a/arch/mips/kernel/mips-mt.c
 +++ b/arch/mips/kernel/mips-mt.c
-@@ -21,26 +21,95 @@
+@@ -21,26 +21,96 @@
  #include <asm/cacheflush.h>
  
  int vpelimit;
  #include <asm/cacheflush.h>
  
  int vpelimit;
 +                      tlbsiz = (((config1val >> 25) & 0x3f) + 1);
 +                      if (tlbsiz > 64)
 +                              tlbsiz = 64;
 +                      tlbsiz = (((config1val >> 25) & 0x3f) + 1);
 +                      if (tlbsiz > 64)
 +                              tlbsiz = 64;
-+                      cpu_data[0].tlbsize = current_cpu_data.tlbsize = tlbsiz;
++                      cpu_data[0].tlbsize = tlbsiz;
++                      current_cpu_data.tlbsize = tlbsiz;
 +              }
 +
 +      }
 +              }
 +
 +      }
  
  /*
   * Dump new MIPS MT state for the core. Does not leave TCs halted.
  
  /*
   * Dump new MIPS MT state for the core. Does not leave TCs halted.
-@@ -78,18 +147,18 @@ void mips_mt_regdump(unsigned long mvpct
+@@ -78,18 +148,18 @@ void mips_mt_regdump(unsigned long mvpct
                        if ((read_tc_c0_tcbind() & TCBIND_CURVPE) == i) {
                                printk("  VPE %d\n", i);
                                printk("   VPEControl : %08lx\n",
                        if ((read_tc_c0_tcbind() & TCBIND_CURVPE) == i) {
                                printk("  VPE %d\n", i);
                                printk("   VPEControl : %08lx\n",
                                break; /* Next VPE */
                        }
                }
                                break; /* Next VPE */
                        }
                }
-@@ -287,6 +356,9 @@ void mips_mt_set_cpuoptions(void)
+@@ -287,6 +357,9 @@ void mips_mt_set_cpuoptions(void)
                printk("Mapped %ld ITC cells starting at 0x%08x\n",
                        ((itcblkgrn & 0x7fe00000) >> 20), itc_base);
        }
                printk("Mapped %ld ITC cells starting at 0x%08x\n",
                        ((itcblkgrn & 0x7fe00000) >> 20), itc_base);
        }
                                flush_icache_all();
 --- a/arch/mips/kernel/vpe.c
 +++ b/arch/mips/kernel/vpe.c
                                flush_icache_all();
 --- a/arch/mips/kernel/vpe.c
 +++ b/arch/mips/kernel/vpe.c
-@@ -77,6 +77,58 @@ static struct kspd_notifications kspd_ev
+@@ -76,6 +76,58 @@ static struct kspd_notifications kspd_ev
  static int kspd_events_reqd;
  #endif
  
  static int kspd_events_reqd;
  #endif
  
  /* grab the likely amount of memory we will need. */
  #ifdef CONFIG_MIPS_VPE_LOADER_TOM
  #define P_SIZE (2 * 1024 * 1024)
  /* grab the likely amount of memory we will need. */
  #ifdef CONFIG_MIPS_VPE_LOADER_TOM
  #define P_SIZE (2 * 1024 * 1024)
-@@ -269,6 +321,13 @@ static void *alloc_progmem(unsigned long
+@@ -268,6 +320,13 @@ static void *alloc_progmem(unsigned long
        void *addr;
  
  #ifdef CONFIG_MIPS_VPE_LOADER_TOM
        void *addr;
  
  #ifdef CONFIG_MIPS_VPE_LOADER_TOM
        /*
         * This means you must tell Linux to use less memory than you
         * physically have, for example by passing a mem= boot argument.
        /*
         * This means you must tell Linux to use less memory than you
         * physically have, for example by passing a mem= boot argument.
-@@ -747,6 +806,12 @@ static int vpe_run(struct vpe * v)
+@@ -746,6 +805,12 @@ static int vpe_run(struct vpe * v)
        }
  
        /* Write the address we want it to start running from in the TCPC register. */
        }
  
        /* Write the address we want it to start running from in the TCPC register. */
        write_tc_c0_tcrestart((unsigned long)v->__start);
        write_tc_c0_tccontext((unsigned long)0);
  
        write_tc_c0_tcrestart((unsigned long)v->__start);
        write_tc_c0_tccontext((unsigned long)0);
  
-@@ -760,6 +825,20 @@ static int vpe_run(struct vpe * v)
+@@ -759,6 +824,20 @@ static int vpe_run(struct vpe * v)
  
        write_tc_c0_tchalt(read_tc_c0_tchalt() & ~TCHALT_H);
  
  
        write_tc_c0_tchalt(read_tc_c0_tchalt() & ~TCHALT_H);
  
        /*
         * The sde-kit passes 'memsize' to __start in $a3, so set something
         * here...  Or set $a3 to zero and define DFLT_STACK_SIZE and
        /*
         * The sde-kit passes 'memsize' to __start in $a3, so set something
         * here...  Or set $a3 to zero and define DFLT_STACK_SIZE and
-@@ -834,6 +913,9 @@ static int find_vpe_symbols(struct vpe *
+@@ -833,6 +912,9 @@ static int find_vpe_symbols(struct vpe *
        if ( (v->__start == 0) || (v->shared_ptr == NULL))
                return -1;
  
        if ( (v->__start == 0) || (v->shared_ptr == NULL))
                return -1;
  
        return 0;
  }
  
        return 0;
  }
  
-@@ -995,6 +1077,15 @@ static int vpe_elfload(struct vpe * v)
+@@ -994,6 +1076,15 @@ static int vpe_elfload(struct vpe * v)
                           (unsigned long)v->load_addr + v->len);
  
        if ((find_vpe_symbols(v, sechdrs, symindex, strtab, &mod)) < 0) {
                           (unsigned long)v->load_addr + v->len);
  
        if ((find_vpe_symbols(v, sechdrs, symindex, strtab, &mod)) < 0) {
                if (v->__start == 0) {
                        printk(KERN_WARNING "VPE loader: program does not contain "
                               "a __start symbol\n");
                if (v->__start == 0) {
                        printk(KERN_WARNING "VPE loader: program does not contain "
                               "a __start symbol\n");
-@@ -1065,6 +1156,9 @@ static int vpe_open(struct inode *inode,
+@@ -1064,6 +1155,9 @@ static int vpe_open(struct inode *inode,
        struct vpe_notifications *not;
        struct vpe *v;
        int ret;
        struct vpe_notifications *not;
        struct vpe *v;
        int ret;
  
        if (minor != iminor(inode)) {
                /* assume only 1 device at the moment. */
  
        if (minor != iminor(inode)) {
                /* assume only 1 device at the moment. */
-@@ -1091,14 +1185,23 @@ static int vpe_open(struct inode *inode,
+@@ -1090,6 +1184,12 @@ static int vpe_open(struct inode *inode,
                cleanup_tc(get_tc(tclimit));
        }
  
                cleanup_tc(get_tc(tclimit));
        }
  
 +#else
        /* this of-course trashes what was there before... */
        v->pbuffer = vmalloc(P_SIZE);
 +#else
        /* this of-course trashes what was there before... */
        v->pbuffer = vmalloc(P_SIZE);
+       if (!v->pbuffer) {
+@@ -1097,11 +1197,13 @@ static int vpe_open(struct inode *inode,
+               return -ENOMEM;
+       }
        v->plen = P_SIZE;
 +#endif
        v->load_addr = NULL;
        v->len = 0;
        v->plen = P_SIZE;
 +#endif
        v->load_addr = NULL;
        v->len = 0;
+-
 +#if 0
        v->uid = filp->f_cred->fsuid;
        v->gid = filp->f_cred->fsgid;
 +#if 0
        v->uid = filp->f_cred->fsuid;
        v->gid = filp->f_cred->fsgid;
  
  #ifdef CONFIG_MIPS_APSP_KSPD
        /* get kspd to tell us when a syscall_exit happens */
  
  #ifdef CONFIG_MIPS_APSP_KSPD
        /* get kspd to tell us when a syscall_exit happens */
-@@ -1351,6 +1454,133 @@ static void kspd_sp_exit( int sp_id)
+@@ -1349,6 +1451,133 @@ static void kspd_sp_exit( int sp_id)
        cleanup_tc(get_tc(sp_id));
  }
  #endif
        cleanup_tc(get_tc(sp_id));
  }
  #endif
  
  static ssize_t store_kill(struct device *dev, struct device_attribute *attr,
                          const char *buf, size_t len)
  
  static ssize_t store_kill(struct device *dev, struct device_attribute *attr,
                          const char *buf, size_t len)
-@@ -1432,6 +1662,18 @@ static int __init vpe_module_init(void)
+@@ -1430,6 +1659,18 @@ static int __init vpe_module_init(void)
                printk("VPE loader: not a MIPS MT capable processor\n");
                return -ENODEV;
        }
                printk("VPE loader: not a MIPS MT capable processor\n");
                return -ENODEV;
        }
  
        if (vpelimit == 0) {
                printk(KERN_WARNING "No VPEs reserved for AP/SP, not "
  
        if (vpelimit == 0) {
                printk(KERN_WARNING "No VPEs reserved for AP/SP, not "
-@@ -1476,10 +1718,12 @@ static int __init vpe_module_init(void)
+@@ -1474,10 +1715,12 @@ static int __init vpe_module_init(void)
        mtflags = dmt();
        vpflags = dvpe();
  
        mtflags = dmt();
        vpflags = dvpe();
  
  
        val = read_c0_mvpconf0();
        hw_tcs = (val & MVPCONF0_PTC) + 1;
  
        val = read_c0_mvpconf0();
        hw_tcs = (val & MVPCONF0_PTC) + 1;
-@@ -1491,6 +1735,7 @@ static int __init vpe_module_init(void)
+@@ -1489,6 +1732,7 @@ static int __init vpe_module_init(void)
                 * reschedule send IPIs or similar we might hang.
                 */
                clear_c0_mvpcontrol(MVPCONTROL_VPC);
                 * reschedule send IPIs or similar we might hang.
                 */
                clear_c0_mvpcontrol(MVPCONTROL_VPC);
                evpe(vpflags);
                emt(mtflags);
                local_irq_restore(flags);
                evpe(vpflags);
                emt(mtflags);
                local_irq_restore(flags);
-@@ -1516,6 +1761,7 @@ static int __init vpe_module_init(void)
+@@ -1514,6 +1758,7 @@ static int __init vpe_module_init(void)
                        }
  
                        v->ntcs = hw_tcs - tclimit;
                        }
  
                        v->ntcs = hw_tcs - tclimit;
  
                        /* add the tc to the list of this vpe's tc's. */
                        list_add(&t->tc, &v->tc);
  
                        /* add the tc to the list of this vpe's tc's. */
                        list_add(&t->tc, &v->tc);
-@@ -1584,6 +1830,7 @@ static int __init vpe_module_init(void)
+@@ -1582,6 +1827,7 @@ static int __init vpe_module_init(void)
  out_reenable:
        /* release config state */
        clear_c0_mvpcontrol(MVPCONTROL_VPC);
  out_reenable:
        /* release config state */
        clear_c0_mvpcontrol(MVPCONTROL_VPC);
 + * Write to perf counter registers based on text input
 + */
 +
 + * Write to perf counter registers based on text input
 + */
 +
-+#define TXTBUFSZ 1024
++#define TXTBUFSZ 100
 +
 +static int proc_write_mtsched(struct file *file, const char *buffer,
 +                              unsigned long count, void *data)
 +
 +static int proc_write_mtsched(struct file *file, const char *buffer,
 +                              unsigned long count, void *data)
 + * Write to perf counter registers based on text input
 + */
 +
 + * Write to perf counter registers based on text input
 + */
 +
-+#define TXTBUFSZ 1024
++#define TXTBUFSZ 100
 +
 +static int proc_write_perf(struct file *file, const char *buffer,
 +                              unsigned long count, void *data)
 +
 +static int proc_write_perf(struct file *file, const char *buffer,
 +                              unsigned long count, void *data)
This page took 0.046513 seconds and 4 git commands to generate.