470 likes | 568 Views
NSPR API Overview . Srinivas Lingutla Wan-Teh Chang Lawrence Hardiman. NSPR 2.0. Netscape Portable Runtime Provides OS/system-level services with a platform- independent API. General purpose platform for use by clients and servers Supported on a large number of platforms including
E N D
NSPR API Overview Srinivas Lingutla Wan-Teh Chang Lawrence Hardiman
NSPR 2.0 • Netscape Portable Runtime • Provides OS/system-level services with a platform- independent API. • General purpose platform for use by clients and servers • Supported on a large number of platforms including • - AIX, Digital Unix, HP-UX, Irix, Solaris, Win95, Windows NT, Linux • - Mac, Win 16, SunOS 4.x, NCR, SCO Unix, Netware, etc,. • Used in most products at Netscape
Basic services • Libnspr • Threads and Synchronization • File and Network I/O • Memory Management • Time Management • Library Management • Support for 64-bit platforms • Atomic Operations • Environment Variables • Instrumentation • Process creation • List management • Debug aids
Miscellaneous libraries • Libplc • String functions • Command line options processing • Libplds • Arenas • Hash tables • Events • Libnsps • Reader/Writer locks
Agenda • Srinivas • Overview • Threads • Synchronization • Atomic operations • Wan-Teh • File and Network I/O • Process Creation • Larry • Time management • Library management • Data types • Instrumentation
Overview • C level API • All services exported through functions (a few are macros) • All exported symbols have the • PR prefix for libnspr • PL prefix for the auxiliary libraries • PS prefix for libnsps • All functions that allocate memory for the caller have a corresponding “free” function • Example: PR_smprintf/PR_smprintf_free • Call PR_GetError to get the NSPR error code when a function fails • Call PR_GetOSError to get the OS error code of the last failed system call in NSPR • All timeout values specified in PRIntervalTime units.
NSPR Threads • Scheduling scope classification • LOCAL • Scheduled by NSPR • Implemented for use by the Client • User-level implementation, faster performance • GLOBAL • Scheduled by the system • Available on all platforms where native threads are present • Each NSPR thread maps to a native thread • User or kernel-level implementation
Thread Models • GLOBAL threads only • - NSPR threads map to pthreads on • AIX 4.2 , Digital Unix 4.0 , HP-UX 11.0 • Solaris 2.5.1, Irix 6.2, Linux 2.1 • - NSPR threads map to Win32 threads on • WIN95 • GLOBAL and LOCAL threads • Irix 6.2 • Global threads map to sprocs • Local threads scheduled by NSPR • WinNT 4.0 • Global threads map to Win32 threads • Local threads are NT Fibers scheduled by NSPR
NSPR Thread APIs • Manipulating threads • PR_CreateThread( PRThreadType type, • void (*start)(void *), • void *arg, • PR_ThreadPriority priority, • PR_ThreadScope scope, • PR_ThreadState, • PRUint32 stackSize) • PR_JoinThread • PR_GetThreadPriority • PR_SetThreadPriority • PR_Interrupt • PR_ClearInterrupt • PR_Sleep
NSPR Thread APIs • Thread Info • PR_GetCurrentThread • PR_GetThreadScope • PR_GetThreadType • PR_GetThreadState • Thread local storage • PR_NewThreadPrivateIndex • PR_SetThreadPrivate • PR_GetThreadPrivate
Locks • PRLock • Classic mutual exclusion locking • Non-reentrant • Not interruptible • Protect data, not code • Use locks for protection, not scheduling • Only hold locks for short periods • Lock management • PRLock *PR_NewLock(void) • PR_DestroyLock(PRLock *) • Lock usage • PR_Lock/PR_Unlock(PRLock *)
Condition variables • PRCondVar • Synchronization between threads - one or more threads can wait for a condition to occur and another thread can notify them when the condition occurs • PRCondVar * PR_NewCondVar(PRLock *) • PR_DestroyCondVar(PRCondVar *) • PR_WaitCondVar(PRCondVar *, PRIntervalTime) • PRLock is unlocked before blocking and reacquired before resuming • PR_NotifyCondVar/PR_NotifyAllCondVar(PRCondVar *) • Notification(s) lost when no thread is waiting
Condition variables - usage • Waiting • Correct method Incorrect • PR_Lock(..) PR_Lock(…) • while (!condition) if (!condition) • PR_WaitCondVar(..) PR_WaitCondVar(..) • …process data …process data • PR_Unlock(…) PR_Unlock(…) • Notification • PR_Lock(..) • ….process data • PR_NotifyCondVar(..) • PR_Unlock(…)
Monitors PRMonitor Reentrant lock Implicit association of a condition variable Cached Monitors Lazy association of Monitors with objects
Atomic operations • Lock-free operations implemented using atomic instructions (Compare-and-Swap, Load-Linked/Store-Conditional, etc) found on some platforms • Counters • PR_AtomicIncrement/Decrement • PR_AtomicAdd • Stack/LIFO-list • PR_CreateStack/DestroyStack • PR_StackPush/StackPop
Reader Writer Locks • Libnsps • Implemented using PRLock and PRCondVar • Resource management • PSRWLock *PS_NewRWLock ( • PRUint32 lock_rank, • const char *lock_name) • PS_DestroyRWLock • Usage • PS_RWLock_Rlock • PS_RWLock_Wlock • PS_RWLock_Unlock
NSPR I/O Functions Wan-Teh Chang
NSPR provides thread-aware file and network I/O functions. Files, sockets, I/O layering, and multiwait receive. Assume familiarity with Unix or Win32 file I/O and Berkeley socket interface. Introduction
Blocking (synchronous): I/O function does not return until I/O is completed. Nonblocking: I/O function fails with EWOULDBLOCKif I/O can’t be completed immediately. Asynchronous: I/O function submits job to OS and returns immediately. Client polls or gets notified of I/O completion. I/O Models
NSPR promotes the multithreaded, blocking I/O programming model. Nonblocking I/O is also available for sockets. Multiwait receive cuts down the number of threads while retaining the simplicity of blocking I/O. Compose I/O functionality by layering. Overview
Open files and sockets are represented by pointers to PRFileDesc structures.PRFileDesc *fd = PR_NewTCPSocket(); I/O methods tables for file, TCP, UDP, and your own I/O abstraction.PR_Read(fd, buf, 1024) ==> fd->methods->read(fd, buf, 1024) Fields for layering, private data, destructor. File Descriptors
Normal (disk) files Blocking mode only: disk I/O is instantaneous. 64-bit file size and offset are supported. File pathnames are char * with Unix-style directory separator /. File I/O
Create, remove directories. Directory listing: hidden files are supported. Not supported: current directory, change directory. Directory I/O
Berkeley sockets style API Blocking and nonblocking modes Blocking functions (PR_Connect, PR_Accept, PR_Send, PR_Recv, PR_SendTo, PR_RecvFrom) can time out or get interrupted. Exploit new system calls: PR_AcceptRead, PR_TransmitFile. Network I/O: Sockets
Use PR_SetSocketOption to set a socket nonblocking. Functions on nonblocking sockets may fail with PR_WOULD_BLOCK_ERROR. Output functions may only transmit part of the send buffer. Call PR_Poll on an array of descriptors to wait until I/O is available. Three events: readable, writable, exception. Nonblocking Sockets
PRNetAddr is a union of IPv4, IPv6 (if enabled), and Unix-domain (on Unix) socket addresses. Hostname/address lookup: PR_GetXXXByYYY String-IP address conversion IPv4/IPv6 transparency Network Address
I/O Layering Buffering Compression (gzip) Encryption (SSL) Raw transport (NSPR) File descriptors may be layered. - Layer ID - Methods
Push & pop layers to/from a stack. Layers must be popped in the reverse order in which they are pushed. Works best with blocking I/O. Tricky and potentially inefficient with nonblocking I/O and PR_Poll. I/O Layering
One thread per connection is simple but can consume lots of resources. Client connections are idle most of the time. Periods of activity start with receiving a client request. Multiwait Receive time Activity Idle Activity Idle
A smaller number of threads block on a group of connections, waiting to receive a client request. Once a request is received, a thread handles it and replies using blocking I/O. Multiwait Receive time Activity Idle Activity Idle
Basic I/O API is similar to Unix/Win32 system calls. I/O functionality can be composed by layering. NSPR promotes multithreaded, blocking I/O programming model for its simplicity and easy of I/O layering. Use of thread resources can be reduced by multiwait receive functions. Summary
PR_CreateProcess: fork+exec PR_WaitProcess Specify attributes of the new process: Current working directory Standard I/O redirection To do: file descriptor inheritance. Process Creation
NSPR Types, Time, Insturmentation Lawrence Hardiman
Prtypes.h PR_EXTERN(type) -- External function declaration PR_IMPLEMENT(type) -- External Function Implementation PR_CALLBACK used for function pointers. Macros wrap platform specific modififers PRIntn -- Native int for platform. Typedef’d to int. PRInt8, PRInt16, PRInt32 -- Signed <n> bit integer. PRUint8, PRUint16, PRUint32 -- Unsigned <n> bit integer. PRSize -- Use it where you want size_t NSPR Types
PRInt64, PRUint64 -- 64 bit signed and unsigned integers. Use the macro operator interfaces to manipulate PRInt64 types even if the platform’s compiler supports 64bit integers. PRBool -- PR_TRUE, PR_FALSE PRPackedBool -- PRInt8 PRStatus -- PR_SUCCESS, PR_FAILUREMany NSPR functions return PRStatus. PRPtrdiff -- Pointer difference PR_BIT -- A structure for bit maps PRCList -- A structure for linked lists.See: prclist.h NSPR Types
Prinrval.h PRIntervalTimeMonotonically increasing integerWraps in about 6 (min) hoursprecision is platform dependent PR_INTERVAL_NO_WAITPR_INTERVAL_NO_TIMEOUTNames for timeout values. Used in NSPR functions taking a timeout argument NSPR Interval Time
PR_IntervalNow() -- Value of NSPR’s runtime clock. PR_SecondsToInterval(), PR_MillisecondsToInterval(), …Converts common time units to NSPR interval time units. PR_IntervalToSeconds(), PR_IntervalToMilliseconds(), …Converts NSPR interval time units to common time units. PR_TicksPerSecond() -- Suitable for arithmetic NSPR Interval Time
Prtime.h PRTime -- Clock time typeNumber of usec since 00:00 GMT, 1-Jan-1970 PRTimeParameters -- Defines variants from GMT. … offsets from GMT to standard and daylight time. PRExplodedTime -- Similar to ‘struct tm’has discrete values for tm_usec, tm_sec, ... NSPR Clock Time
PR_ExplodeTime(), PR_ImplodeTime()Convert between PRTime and PRExplodedTime. (*PRTimeParamFn()) -- Adjusts a PRExplodedTime to GMT or local time. PR_GMTParameters() -- adjusts to GMT PR_LocalTimeParameters()A thin wrapper to ‘localtime()’. Want precision? … Roll your own. NSPR Clock Time
Prlink.h PRLibrary -- Opaque structure PR_LoadLibrary(), PR_UnloadLibrary()load and unload a shared library PR_FindSymbol() …other functions NSPR Library Management
Prlog.h PRLogModuleInfo -- Logging structure PR_NewLogModule() -- Create a log PR_LOG() -- conditionally write to log Environment variable control NSPR_LOG_MODULESmodulename:level, ... NSPR_LOG_FILEfilespec or “WinDebug” NSPR Logging
Prcountr.h Compile time conditionedDEBUG, FORCE_NSPR_COUNTERS API to create by nameTwo level name lookup“handle” reference is fast API increment, decrement, … API to find all counters by nameExtract values NSPR Counters
Prtrace.h Compile time conditionedDEBUG, NSPR_FORCE_TRACE API to create by nameTwo level name space API to cause a trace entry API to control trace operationsenable, disable, suspend, resume API to cause write to external file NSPR In-memory trace
Status • NSPR binary releases will be available periodically • Current release, v3.0, released Oct-2-98 • Next release scheduled for Feb’99 • Use only the binary releases of NSPR • Release names of the form Major.Minor.Patch number • Newer minor releases are backward compatible • A function, libVersionPoint, exported to provide library version information, PRVersionDescription • Requirements/suggestions collected from Netscape developers • Use Bugsplat (Scopus database) to file bug reports
Status - Mozilla.org • NSPR2.0 is part of open source available at Mozilla.org • Replaces NSPR 1.0 in Netscape Client 5.0 • Built and used as a stand-alone runtime • Being tested for inclusion in other open-source projects such as Apache and Japhar (JVM) on the Net • NSPR is subject to NPL (Netscape Public License) • NSPS is a Netscape-internal library (non-NPL) • Contributions received from the Net developers (patches and ports to new platforms)
Future • Implement additional services • Process-level facilities • IPC • Metering information • Debug aids • Performance improvements • I/O thruput • Threads and synchronization • Stability • Code coverage, more extensive QA testing • Engage the net
Reference • Internal homepage • http://warp/projects/hardcore/prj-nspr20 • Documentation • http://www.mozilla.org/docs/refList/refNSPR/ • Source code • ns/nspr20 • Test programs • ns/nspr20/pr/tests • NSPR20 team mail alias • nsprgroup • NSPR20 clients mailing list • nspr20clients • NSPR newsgroup at Mozilla.org • news://news.mozilla.org/netscape.public.mozilla.nspr