Application development on Solaris OS using Sun Studio compilers and tools
Solaris Developer
ABOUT

We are the Solaris Developer Information Products Team:
Richard Friedman, David Lindt, Kami Shahi, Jyothi Srinath, Paul Echeverri, Ann Rice, Alta Elstad, Susan Morgan, Frank Jennings

DOCUMENTATION
»Solaris OS
»Sun Studio Compilers/Tools

ARTICLES
»Solaris OS
»Sun Studio Compilers/Tools

DOWNLOADS
»Solaris OS
»Sun Studio Compilers/Tools

RECENT ENTRIES
Archives
Click me to subscribe
Search

Links
 

Today's Page Hits: 72

Main | Next page »
Wednesday Mar 26, 2008
Enter! Win$

Reminder: OpenSolaris Community Innovation Awards

Go to awards.opensolaris.org to register, declare an entry, and submit your entry. See the updated information on the OpenSolaris Community Innovation Awards Program site. Before you can register for the contest, you must already be registered as an OpenSolaris.org member. Before you can submit an entry, you must already have an SCA number. All types of entries are welcome. Deadline is June 13, 2008. See the web site for prizes, details on how to enter, and other information.


Posted at 08:21AM Mar 26, 2008 by Alta Elstad in Compilers  |  Comments[0]

Tuesday Mar 25, 2008
Tracing PHP Function Calls Using DTrace
In NetBeans, you can use the DTrace plug-in to analyze the performance of your PHP applications. A DTrace provider for PHP that adds probes to function entry and exit points has been available through Cool Stack. The support is also provided through Web Stack, if you are using SXDE 1/08.

To get started, follow these tutorials:
1.Configure NetBeans for DTrace.
2.Get PHP DTrace Extension.

Once you are done with the steps provided in the above articles, start your Apache web server and check the probes.

bash-3.2# dtrace -l | grep php

17952    php1895         dtrace.so       php_dtrace_execute function-entry
17953    php1895         dtrace.so       php_dtrace_execute_internal function-entry
17954    php1895         dtrace.so       php_dtrace_execute function-return
17955    php1895         dtrace.so       php_dtrace_execute_internal function-return
17956    php1896         dtrace.so       php_dtrace_execute function-entry
......
......

I'm running a simple PHP application that has some function calls. Go to the DTrace window in the NetBeans IDE and start the
php_flowtime.d
script.



Here is my output. The output shows which function is being invoked and the invoke time.



My example has only a few SOAP calls. If you have a complex application with DB calls, this script will be useful to analyze the performance bottlenecks in your application.


Posted at 09:44AM Mar 25, 2008 by Phantom Reference in Debugging  |  Comments[1]

Thursday Feb 07, 2008
Sorting out Solaris Releases

To sort out the various Solaris flavors, watch a quick 10-minute webcast that introduces you to the differences between the Solaris 10 OS, SXDE, OpenSolaris and Indiana.

The webcast can be viewed here.


Posted at 08:31PM Feb 07, 2008 by Jyothi Srinath in General  |  Comments[0]

Wednesday Jan 30, 2008
Win Cash! Community Innovation Awards Programs

Participate in the Open Source Community Innovation Awards Programs!

Open Source Communities Announce Participation Details For Sun Sponsored $1Million Innovation Awards Program

Community Innovation Awards Program web site

Each of the following six open source communities is giving away $175,000 (USD). Each community has specified its own contest with its own rules. Prize winners will be announced in August 2008 and payments made by the end of September 2008.

The OpenSolaris community also will be announcing a student research grant program.


Posted at 12:29PM Jan 30, 2008 by Alta Elstad in General  |  Comments[0]

Friday Jan 11, 2008
Technical Articles: Performance Tuning with Sun Studio Compilers and Tools
Here's a list of interesting technical articles on application performance tuning that are currently on the Sun Developer Network portal.

Posted at 02:50PM Jan 11, 2008 by Richard Friedman in Performance  | 

Wednesday Jan 09, 2008
Sun HPC ClusterTools 7.1 Released

Sun HPC ClusterTools 7.1 is now available!

Sun HPC ClusterTools 7.1 is an update release based on Open MPI 1.2.4. Included in Sun HPC ClusterTools 7.1 are Intel 32- and 64-bit support, improved parallel debugger support, PBS Pro validation, improved memory usage for communication, and other bug fixes by the Open MPI community since Open MPI 1.2 was first released.

Sun HPC ClusterTools 7.1 software supports:

  • Sun Ultra SPARC III or greater, Opteron, or Intel systems
  • Solaris 10 11/06 Operating System
  • Sun Studio 10, 11 and 12
  • Shared memory, TCP, and Infiniband communication
  • The full MPI-2 specifications
  • Download from http://www.sun.com/software/products/clustertools/index.xml 

    Open MPI is the open source version of the MPI parallel programming API.
    » Learn more about Open MPI


    Posted at 09:46AM Jan 09, 2008 by Richard Friedman in Multithreading  | 

    Wednesday Jan 02, 2008
    NEW BOOK: Solaris Application Programming

    Solaris Application Programming, by Sun engineer Darryl Gove, has just been published by Sun Press/Prentice Hall.

    Here's the back-of-the-jacket blurb:

    Solaris™ Application Programming is a comprehensive guide to optimizing the performance of applications running in your Solaris environment. From the fundamentals of system performance to using analysis and optimization tools to their fullest, this wide-ranging resource shows developers and software architects how to get the most from Solaris systems and applications.


    Whether you’re new to performance analysis and optimization or an experienced developer searching for the most efficient ways to solve performance issues, this practical guide gives you the background information, tips, and techniques for developing, optimizing, and debugging applications on Solaris.


    The text begins with a detailed overview of the components that affect system performance. This is followed by explanations of the many developer tools included with Solaris OS and the Sun Studio compiler, and then it takes you beyond the basics with practical, real-world examples. In addition, you will learn how to use the rich set of developer tools to identify performance problems, accurately interpret output from the tools, and choose the smartest, most efficient approach to correcting specific problems and achieving maximum system performance.


    Coverage includes


    Posted at 01:07PM Jan 02, 2008 by Richard Friedman in General  |  Comments[1]

    Friday Dec 21, 2007
    Live Streaming Video

    Here we are playing with live streaming video at the December meeting of the Silicon Valley Open Solaris User Group: http://www.ustream.tv/channel/svosug/

    .

    Tune in next month for more exciting content!:)


    Posted at 01:05AM Dec 21, 2007 by Alta Elstad in General  | 

    Tuesday Dec 18, 2007
    Contest Includes Drivers, Applications, Documentation, and Research

    Sun is sponsoring several contests, and prize money is designated for the Solaris/OpenSolaris OS in the areas of device drivers, applications, documentation, and undergraduate research.

    Join the contest planning here:
    OpenSolaris Community Innovation Awards
    Awards program email archives

    What drivers, applications, and documentation does the Solaris OS need? What research should be done? How much prize money should be awarded for different types of projects? How should entries be judged? By whom?

    Contest announcement

    Community Innovation Awards Program web site


    Posted at 12:41AM Dec 18, 2007 by Alta Elstad in General  | 

    Friday Dec 14, 2007
    NetBeans IDE 6.0 now available with features that will be in the next Sun Studio IDE

    NetBeans IDE 6.0 is now available for download at http://download.netbeans.org/netbeans/6.0/final/. Select the C/C++ bundle, which includes the base IDE and C/C++ support. Installation on Solaris, Linux, Windows, or Mac OS X is quick and simple.

    You can create projects now using NetBeans IDE 6.0, and work with these projects in the next release of the Sun Studio IDE.

    New features added to the C/C++ support in this release of NetBeans IDE 6.0 will be available in the Sun Studio IDE in SXDE 1/08 and Sun Studio Express 1/08, which will be released in January/February. These features include:

    - Improvements in the Classes window, which lets you see all the classes in your project and their members and fields.

    - New Include hierarchy, which lets you inspect the hierarchy of source and header files in your project

    - New Type hierarchy, which lets you inspect all types and subtypes of a class

    - Code completion for #include directives 

     

     

     

     



    Posted at 03:51PM Dec 14, 2007 by Ann Rice in General  | 

    Sunday Dec 09, 2007
    Setting up memcached on Solaris
    These days everyone seems to use memcached, a high-performance, distributed memory object caching system, intended for use in speeding up web applications. Performance can be greatly improved from moving away from disk fetch to a RAM fetch. Here is an excellent article explaining memcached taking LiveJournal as a case study.
    Do you know that memcached daemons can be set up on Solaris Zones too? For this you need to download memcached package from the Cool Stack site.

    What you need to get?
    1. Cool Stack 1.2
    2. memcached Java Client APIs (Get this jar and this jar).

    Create and Boot Zones
    Create 3 zones - zonea, zoneb and zonec to test memcached. For information on creating Solaris zones read this article.

    I'm using SXDE 9/07
    OK you don't have SXDE? Get it!

    Here is the status of my zones:

    # zoneadm list -vc
    ID NAME STATUS PATH BRAND IP
    0 global running / native shared
    4 zonea running /zones/zonea native shared
    5 zoneb running /zones/zoneb native shared
    6 zonec running /zones/zonec native shared


    Start memcached on all Zones

    Follow the Cool Stack site for installing Cool Stack on your zones. When you do a pkgadd -d <memcached*.pkg>, memcached gets installed in all the available zones even though they are not in a running state.

    When everything is set, these commands should work fine:

    zonea# ./opt/coolstack/bin/memcached -u phantom -d -m 100 -l 129.158.224.242 -p 11111
    zoneb# ./opt/coolstack/bin/memcached -u phantom -d -m 100 -l 129.158.224.231 -p 11112
    zonec# ./opt/coolstack/bin/memcached -u phantom -d -m 100 -l 129.158.224.243 -p 11113


    Start memcached as non-root user on all all zones with 100 MB memory bucket. This should be OK for testing but ideally in a production setup it should be around a terabyte.

    If you don't know already, each Solaris zone can bind to an IP and port through the virtual interface. So you don't need 3 NICs or 3 machines - but just 3 zones.

    Test memcached

    Set the classpath pointing to the downloaded jars. Use NetBeans for simplicity. Store an object in-memory and retrieve it from the memcached daemon running on zonea:

            ....
        //Interact with zonea
        MemcachedClient c;
        try {
            c = new MemcachedClient(new InetSocketAddress
                    ("129.158.224.242", 11111));

            String test=new String("I'm going to be cached!");
            c.set("mykey", 180, test);
            Object obj=c.get("mykey");
            System.out.println((String)obj);
            c.delete("mykey");
        } catch (IOException ex) {
            ex.printStackTrace();
        }

           ...

    We are storing an object for 3 mins. After retrieving the object, you can clean the cache. When you compile and run the program,  the output will look like:

    2007-10-03 10:38:49.615 INFO net.spy.memcached.MemcachedConnection: Connected to {QA sa=/129.158.224.242:11111, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=0} immediately
    I'm going to be cached!


    From your code, you can also connect to multiple memcached servers and store objects.
    This is quite interesting. You can halt one zone and can try to store object in-memory on all the three zones.

    # zoneadm -z zonea halt
    # zoneadm list -vc
    ID NAME STATUS PATH BRAND IP
    0 global running / native shared
    5 zoneb running /zones/zoneb native shared
    6 zonec running /zones/zonec native shared
    - zonea installed /zones/zonea native shared

    Now zonea is no longer running memcached because zonea zone is down.
    Here is the modified code:

        MemcachedClient c;
        try {
            //zonea, zoneb and zonec
            c=new MemcachedClient(AddrUtil.getAddresses
                ("129.158.224.242:11111
                  129.158.224.231:11112   
                  129.158.224.243:11113"))
    ;

            String test=new String("I'm going to be cached on all zones!");
            c.set("mykey2", 180, test);
            Object obj=c.get("mykey2");
            System.out.println((String)obj);
            c.delete("mykey2");
        } catch (IOException ex) {
            ex.printStackTrace();
        }

    We are trying to store the object on all the available servers. But zonea is offline.
    Here is the output:

    2007-10-03 11:18:27.678 INFO net.spy.memcached.MemcachedConnection:
    Added {QA sa=/129.158.224.242:11111, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=0} to connect queue

    2007-10-03 11:18:27.682 INFO net.spy.memcached.MemcachedConnection:

    Connected to {QA sa=/129.158.224.231:11112, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=0} immediately

    2007-10-03 11:18:27.684 INFO net.spy.memcached.MemcachedConnection:

    Connected to {QA sa=/129.158.224.243:11113, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=0} immediately

    I'm going to be cached on all zones!


    The object is queued for insertion whenever zonea comes up. It would be interesting to test the automatic failover behavior of memcached considering the fact that memcached is a mother of all hashtables and there should be sufficient fail safe plumbing required between running instances of memcached daemons. You can also use DTrace for memcached debugging.



    Posted at 10:49PM Dec 09, 2007 by Phantom Reference in Performance  |  Comments[4]

    Wednesday Dec 05, 2007
    Solaris Developers - Contribute and Get Cash

    Sun has launched a "multi-year program called the Open Source Community Innovation Awards Program." OpenSolaris is one of six Sun open source projects that is included in this new award program. View the announcement.

    Details will be available in January 2008. Stay tuned.

    In the mean time, learn more about OpenSolaris and how you can contribute.


    Posted at 06:55PM Dec 05, 2007 by Alta Elstad in General  | 

    Tuesday Dec 04, 2007
    Sun Studio and Solaris Information Centers

    We keep trying to find ways to make the product documentation for Solaris and the Sun Studio tools easier to find and browse.

    One way we've found is by creating "Information Centers" containing links to all the relevant documentation.

    The Information Center for the Solaris OS can be found at
    http://www.sun.com/bigadmin/hubs/documentation/

    We have also just created an information center for all the documentation around the Sun Studio compilers and tools. It's on docs.sun.com at
    http://docs.sun.com/source/820-3845/stdinfoctr.html

    The Sun Studio Information Center also contains a link to pages for all the compiler options, organized by compiler and task. Because not all similar options are spelled exactly alike in C, C++, and Fortran, this list of comparisons can be very handy.

    You can find the compiler options page at:
    http://docs.sun.com/source/820-3529/index.html

    Let us know if you find these pages useful.


    Posted at 01:51PM Dec 04, 2007 by Richard Friedman in General  |  Comments[3]

    Join the Sun HPC Community

    Join the Sun High Performance computing community, http://hpc.sun.com. We're putting this dedicated HPC web resource together for all Sun customers, partners and Sun employees. Its not like a traditional web portal;  post your own content, leave comments on existing content, or add new content to existing pages.

    We're adding new content daily. Use it as a aggregation point for all information relating to high performance computing. And we're open to new ideas about what we should dish out on the site.

     

     

     



    Posted at 12:55PM Dec 04, 2007 by Richard Friedman in General  | 

    Thursday Nov 08, 2007
    New Book: USING OPENMP

    Using OpenMP MIT PressIn October, MIT Press published the first really comprehensive book on parallel programming using the OpenMP API.

    Using OpenMP,
    Portable Shared Memory Parallel Programming, by Barbara Chapman, Gabriele Jost and Ruud van der Pas, with a foreword by David J. Kuck, covers shared-memory parallelization on a number of platforms.

    I've had a pre-publication peek at it (because one of the authors, Ruud van der Pas, is a Sun engineer I work very closely with), and I can say that it packs a lot of very useful information in one place.

    Most useful is a discussion of how cache lines can interfere with OpenMP parallelization and cause performance and scaling degradation if you are not aware of what's going on.

    This will be a very valuable book on my shelf when it's available.

     

     


    Posted at 07:51AM Nov 08, 2007 by Richard Friedman in Compilers  | 

    OpenMP 3.0 Spec Open For Public Comment

    The OpenMP ARB is pleased to announce the release of a draft of Version 3.0 of the OpenMP specification for public comment. This is the first update to the OpenMP specification since 2005.

    This release adds several new features to the OpenMP specification, including:

    Larry Meadows, CEO of the OpenMP organization, states: "The creation of OpenMP 3.0 has taken very hard work by a number of people over more than two years. The introduction of a unified tasking model, allowing
    creation and execution of unstructured work, is a great step forward for OpenMP. It should allow the use of OpenMP on whole new classes of computing problems."

    The draft specification is available in PDF format from the Specifications section of the OpenMP ARB website:

    http://www.openmp.org

    (Direct link:
    http://www.openmp.org/drupal/mp-documents/spec30_draft.pdf)

    Mark Bull has led the effort to expand the applicability of OpenMP while improving it for its current uses as the Chair of the OpenMP Language Committee. He states: "The OpenMP language committee has done a fine job
    in producing this latest version of OpenMP. It has been difficult to resolve some tricky details and understand how tasks should propagate across the language. But I think we have come up with solid solutions, and the team should be proud of their accomplishment."

    The ARB warmly welcomes any comments, corrections and suggestions you have for Version 3.0. For Version 3.0, we are soliciting comments through an on-line forum, located at http://www.openmp.org/forum. The forum is entitled Draft 3.0 Public Comment. You can also send email to feedback-AT-openmp.org if you would rather not use the forum. It is most helpful if you can refer to the page number and line number where appropriate.

    The public comment period will close on 31 January 2008.

    Posted at 07:49AM Nov 08, 2007 by Richard Friedman in Compilers  | 

    The Book On Parallel Programming

    Wilkinson/Allen: Parallel ProgrammingWilkinson and Allen's PARALLEL PROGRAMMING was published in 1999 (Prentice Hall). A revised edition came out in 2005. And I finally got my hands on it.

    It IS expensive.  Maybe you can now find used copies (be sure it's the 2nd edition!)

    Used as a computer science text, it is a complete course on parallel programming techniques and algorithms, and covers MPI, Pthreads, and MPI. The new material covers distributed shared memory systems (DSM).

    And, as a course, it is rich with examples and end-of-chapter homework problems. Some of them are really creative, like: "Write a multithreaded program to simulate two automatic teller machines being accessed by different persons on a single shared account."

    Some of the typical parallel applications explored are image processing, numerical algorithms, and sorting and searching techniques. 

    I went thru the first edition (minus the problems) when it first came out. Now this expanded revised edition has me totally entranced, again.  This is a great book, and I highly recommend it to anyone thinking seriously about parallel programming, especially for technical computing applications.


    Posted at 07:44AM Nov 08, 2007 by Richard Friedman in Multithreading  | 

    Monday Oct 08, 2007
    Learning About Parallel Programming

    Clearly, multithreaded or parallel programming is growing in importance as the new chip architectures move towards multiple cores and multiple threads rather than merely upping clock cycle times.

    But parallel programming is hard, no doubt about it. It's so much easier to cast a computational problem into a serial, one-step-at-a-time framework than think of it in terms of data distribution over networks of compute nodes.

    So how do you learn parallel programming?

    Luckily there are a number of resources on the web. Here are just a few links


    Posted at 11:40AM Oct 08, 2007 by Richard Friedman in Multithreading  | 

    Wednesday Jun 27, 2007
    Making Sense of Parallel Programming Terms
    Making Sense of Parallel Programming Terms is an article that ties together much of the terminology of multithreaded or parallel programming. 

    Posted at 04:35PM Jun 27, 2007 by morganic in Multithreading  | 

    New Article: Prefetching

    Prefetching Pragmas and Intrinsics

    Diane Meirowitz, Senior Staff Engineer, and Spiros Kalogeropulos, Staff Engineer, June, 2007

    Introduction

    Explicit data prefetching pragmas and intrinsics for the x86 platform and additional pragmas and intrinscs for the SPARC platform are now available in Sun Studio 12 compilers, released June 2007.

    Prefetch instructions can increase the speed of an application substantially by bringing data into cache so that it is available when the processor needs it. This benefits performance because today's processors are so fast that it is difficult to bring data into them quickly enough to keep them busy, even with hardware prefetching and multiple levels of data cache.

    The compilers have several options that enable them to generate prefetch instructions automatically: -xprefetch, -xprefetch_level, and -xprefetch_auto_type (described below). The compilers generally do an excellent job of inserting prefetch instructions, and this is the most portable and best way to use prefetch. If finer control of prefetching is desired, prefetch pragmas or intrinsics can be used. Note that the performance benefit due to prefetch instructions is hardware-dependent and prefetches which improve performance on one chip may not have the same effect on a different chip. It is a good idea to study the instruction reference manual for the target hardware before inserting prefetch pragmas or intrinsics. Furthermore, the Sun Studio Performance Analyzer can be used to identify the cache misses of an application.


    [Read More]

    Posted at 10:42AM Jun 27, 2007 by Richard Friedman in Compilers  | 

    Monday Jun 25, 2007
    Project D-Light Tutorial

    D-Light Tutorial

    Project D-Light is a plug-in for Sun Studio 12. The plug-in offers a variety of instrumentation that takes advantage of the DTrace debugging and performance analysis functionality in the Solaris Operating System.

    Project D-Light System Requirements

    Project D-Light currently only runs on the Solaris 10 OS and requires a DTrace enabled Java Runtime Environment, at least version 6. The Solaris Express Developer Edition 05/07 OS, which is available free of charge from http://developers.sun.com/solaris/downloads/solexpdev/, is the recommended platform to run the tool. To check your Solaris version, type cat /etc/release at a shell prompt.

     

    [Read More]

    Posted at 02:20PM Jun 25, 2007 by Paul Echeverri in Debugging  |  Comments[1]

    Saturday Jun 23, 2007
    Technical Articles on Performance Tuning

    Here's a list of the current SDN articles dealing with tuning and optimization of applications on Solaris using Sun Studio compilers: 

    Performance Tuning With Sun Studio Compilers and Inline Assembly Language
    Here are examples of using a compiler flag or inline assembly language with Sun Studio compilers to increase the performance of C, C++, and Fortran programs. (June 4, 2007)
     
    Profiling WebSphere Application Servers with Sun Studio Performance Tools
    This article describes how to profile an IBM WebSphere Application Server (WAS) runtime environment with the Sun Studio Performance Analysis Tools, Collector and Analyzer. (January 30, 2007)
     
    Cool Tools: Using SHADE to Trace Program Execution by Darryl Gove

    The SHADE library is an emulator for SPARC hardware. The particular advantage of using SHADE is that it is possible to write an analysis tool which gathers information from the application being emulated. The SHADE library comes with some example analysis tools which track things like the number of instructions executed or the frequency that each type of instruction is executed. A more advanced analysis tool might look at cache misses that the application encounters for a given cache structure.
    (September 29, 2006)

    Click on the link below to see the complete list-
    [Read More]

    Posted at 11:57AM Jun 23, 2007 by Richard Friedman in Tuning/Optimization  |  Comments[4]

    Friday Jun 22, 2007
    C and C++ Technical Articles

    There are a lot of useful, short, technical articles on the SDN portal directed at the C and C++ programmer on Solaris. 

    New Language Extensions in the Sun Studio 12 C Compiler
    This article gives an overview of the C-language extensions (part of the GNU C-implementation) introduced in the Sun Studio 12 C compiler. Although these extensions are not part of the latest ISO C99 standard, they are supported by the popular gcc compilers. (June 13, 2007)
     
    A Look Inside a Solaris C++ Shared Libraries Patch
    Ever wonder what's in a patch? Take a look inside a typical Sun Studio compiler patch that includes updated C++ shared libraries. (November 10, 2006)
     
    Comparing C++ Standard Libraries
    The Sun C++ compiler ships with two libraries that implement the C++ standard library: libCstd and libstlport. This article discusses the differences between the two libraries and explores the situations in which one library is preferred over the other. (May 17, 2006)
     
    Reducing Symbol Scope with Sun Studio C/C++
    Hiding non-interface symbols of a library within the library makes the library more robust and less vulnerable to symbol collisions from outside the library. To get the appropriate linker scoping in a source program, you can now use language extensions built into the Sun Studio C/C++ compilers. (May 17, 2005)
     
    Mixed-Language Programming and External Linkage
    The author shows how a simple C++ program fails without language linkage, but can succeed with proper linkage. (This article is on the Solaris portal.) (March 23, 2005)
     
    Using DTrace to Profile and Debug A C++ Program
    In this test case, the DTrace capability in the Solaris 10 OS is used to identify an error common to C++ applications -- the memory leak. (This article is on the Solaris OS developer portal.) (February 17, 2005)
     
    Mixing C and C++ Code in the Same Program
    The C++ language provides mechanisms for mixing code that is compiled by compatible C and C++ compilers in the same program. You can experience varying degrees of success as you port such code to different platforms and compilers. This article shows how to solve common problems that arise when you mix C and C++ code, and highlights the areas where you might run into portability issues. (July 25, 2003)
     
    Using the C/C++ Garbage Collection Library, libgc
    This article discusses some of the runtime errors related to memory management and how you can use the garbage collection library, libgc to fix these errors. In most cases, just linking with the library without making any changes to your code will fix the errors. (July 25, 2003)
     
    How to Use the restrict Qualifier in C
    Using the restrict qualifier appropriately in C programs may allow the compiler to produce significantly faster executables. (July 17, 2003)
     
    The Stability of the C++ ABI
    A discussion of the evolution of the C++ Application Binary Interface, and its implications. (March 20,2003)
     
    Developing on the New Solaris Platform While Supporting Older Versions
    Application software developers can learn to use the latest version of the Solaris OS while supporting previous versions. (January 1, 2002)
     

    Posted at 06:05PM Jun 22, 2007 by Richard Friedman in Compilers  | 

    New Article: Fortran Library Functions - How To Call Them

    Here's a new article from Michael Ingrassia, one of the lead developers in the Fortran Compiler team at Sun:

     

    HOW TO CALL A LIBRARY FUNCTION OR SUBROUTINE FROM FORTRAN

    The Fortran language, both the standard language adhered to by all vendors and the extended language offered to Sun customers, contains several different models for how to call library functions. Confusion can result if you aren't clear about which model you should use for the particular library function you are calling. In this paper we try to describe the different models and provide examples of what might go wrong.

    In general, any function found in a library can be called from Fortran. (Subroutines are rarer; for convenience we'll consistently refer to functions in this article where we should properly say function/subroutine). Here's a recipe for how to do it, which contains several specific recommendations for good coding practices.

    To start , gather the following information:

    Depending on what you find, there are 5 different models determining how to properly call this function:

    Lets look at each situation in detail.

     

    [Read More]

    Posted at 02:49PM Jun 22, 2007 by Richard Friedman in Compilers  | 

    Thursday Jun 14, 2007
    Sun Studio 12 IDE Quick Start Tutorial
    Sun Studio IDE screenshot

    There's now a quick-start tutorial guide for using the new Sun Studio 12 IDE. It's here.




    Posted at 12:27PM Jun 14, 2007 by Richard Friedman in General  |