*** empty log message ***
authorthomas <thomas>
Fri, 6 Sep 1996 00:07:06 +0000 (00:07 +0000)
committerthomas <thomas>
Fri, 6 Sep 1996 00:07:06 +0000 (00:07 +0000)
sysdeps/mach/hurd/i386/init-first.c
sysdeps/mach/hurd/profil.c
sysdeps/mach/hurd/sendto.c

index d095580..5203b4c 100644 (file)
@@ -31,15 +31,16 @@ extern void __libc_global_ctors (void);
 
 int __libc_multiple_libcs = 1;
 
+int __libc_argc;
+char **__libc_argv;
+
 void *(*_cthread_init_routine) (void); /* Returns new SP to use.  */
 void (*_cthread_exit_routine) (int status) __attribute__ ((__noreturn__));
 
-
 /* Things that want to be run before _hurd_init or much anything else.
    Importantly, these are called before anything tries to use malloc.  */
 DEFINE_HOOK (_hurd_preinit_hook, (void));
 
-
 static void
 init1 (int argc, char *arg0, ...)
 {
@@ -47,6 +48,8 @@ init1 (int argc, char *arg0, ...)
   char **envp = &argv[argc + 1];
   struct hurd_startup_data *d;
 
+  __libc_argc = argc;
+  __libc_argv = argv;
   __environ = envp;
   while (*envp)
     ++envp;
index 431982e..41c7c4b 100644 (file)
@@ -36,6 +36,7 @@ static size_t sample_scale;
 static sampled_pc_seqno_t seqno;
 static struct mutex lock = MUTEX_INITIALIZER;
 static mach_msg_timeout_t collector_timeout; /* ms between collections.  */
+static int profile_tick;
 
 /* Enable statistical profiling, writing samples of the PC into at most
    SIZE bytes of SAMPLE_BUFFER; every processor clock tick while profiling
@@ -62,8 +63,7 @@ update_waiter (u_short *sample_buffer, size_t size, size_t offset, u_int scale)
 
   if (! err)
     {
-      int tick;                        /* Microseconds per sample.  */
-      err = __task_enable_pc_sampling (__mach_task_self (), &tick,
+      err = __task_enable_pc_sampling (__mach_task_self (), &profile_tick,
                                       SAMPLED_PC_PERIODIC);
       if (!err && sample_scale == 0)
        /* Profiling was not turned on, so the collector thread was
@@ -79,7 +79,7 @@ update_waiter (u_short *sample_buffer, size_t size, size_t offset, u_int scale)
             and the kernel buffer size we get the length of time it takes
             to fill the buffer; translate that to milliseconds for
             mach_msg, and chop it in half for general lag factor.  */
-         collector_timeout = MAX_PC_SAMPLES * tick / 1000 / 2;
+         collector_timeout = MAX_PC_SAMPLES * profile_tick / 1000 / 2;
        }
     }
 
@@ -87,6 +87,12 @@ update_waiter (u_short *sample_buffer, size_t size, size_t offset, u_int scale)
 }
 
 int
+__profile_frequency ()
+{
+  return profile_tick;
+}
+
+int
 profil (u_short *sample_buffer, size_t size, size_t offset, u_int scale)
 {
   error_t err;
index 88026b8..1be2cbb 100644 (file)
@@ -27,13 +27,12 @@ Cambridge, MA 02139, USA.  */
 /* Send N bytes of BUF on socket FD to peer at address ADDR (which is
    ADDR_LEN bytes long).  Returns the number sent, or -1 for errors.  */
 int
-sendto (fd, buf, n, flags, addr, addr_len)
-     int fd;
-     const void *buf;
-     size_t n;
-     int flags;
-     const struct sockaddr_un *addr;
-     size_t addr_len;
+sendto (int fd,
+       const void *buf,
+       size_t n,
+       int flags,
+       const struct sockaddr_un *addr,
+       size_t addr_len)
 {
   addr_port_t aport;
   error_t err;