C Memory Object and Value Semantics: the Space of De Facto and ISO Standards

Total Page:16

File Type:pdf, Size:1020Kb

C Memory Object and Value Semantics: the Space of De Facto and ISO Standards DRAFT – WORK IN PROGRESS C memory object and value semantics: the space of de facto and ISO standards [This revises and extends WG14 N2013] Revision: 1571 2016-03-17 David Chisnall Justus Matthiesen Kayvan Memarian Peter Sewell Robert N. M. Watson University of Cambridge http://www.cl.cam.ac.uk/~pes20/cerberus/ Contents 2.3.1 Q8. Should intra-object pointer sub- traction give provenance-free inte- 1 Introduction5 ger results?............. 15 1.1 Experimental Testing............6 2.3.2 Q9. Can one make a usable off- 1.2 Summary of answers............7 set between two separately allocated objects by inter-object subtraction 2 Abstract Pointers7 (using either pointer or integer arith- 2.1 Pointer Provenance.............7 metic), to make a usable pointer to the second by adding the offset to 2.1.1 Q1. Must the pointer used for the first?............... 16 a memory access have the right provenance, i.e. be derived from 2.3.3 Q10. Presuming that one can the pointer to the original alloca- have valid pointers with multiple tion (with undefined behaviour oth- provenances, does an inter-object erwise)? (This lets compilers do pointer subtraction give a value with provenance-based alias analysis)..7 explicitly-unknown provenance or 2.1.2 Q2. Can equality testing on pointers something more specific?...... 18 be affected by pointer provenance 2.3.4 Q11. Is the XOR linked list idiom information?............9 supported?............. 18 2.1.3 GCC and ISO C11 differ on the re- 2.3.5 Q12. For arithmetic over prove- sult of a == comparison on a one- nanced integer values, is the prove- past pointer............. 10 nance of the result invariant under 2.2 Pointer provenance via integer types.... 10 plus/minus associativity?...... 19 2.2.1 Q3. Can one make a usable pointer 2.3.6 Multiple provenance semantics via casts to intptr t and back?.. 10 summarised............. 19 2.2.2 Q4. Can one make a usable pointer 2.4 Pointer provenance via pointer representa- via casts to unsigned long and tion copying................. 19 back?................ 10 2.4.1 Q13. Can one make a usable copy of 2.2.3 Q5. Must provenance information a pointer by copying its representa- be tracked via casts to integer types tion bytes using the library memcpy? 19 and integer arithmetic?....... 12 2.4.2 Q14. Can one make a usable copy of 2.2.4 Q6. Can one use bit manipulation a pointer by copying its representa- and integer casts to store informa- tion bytes (unchanged) in user code? 20 tion in unused bits of pointers?... 14 2.4.3 Q15. Can one make a usable copy 2.2.5 Q7. Can equality testing on integers of a pointer by copying its repre- that are derived from pointer values sentation bytes by user code that in- be affected by their provenance?.. 15 directly computes the identity func- 2.3 Pointers involving multiple provenances.. 15 tion on those bytes?......... 20 1 2016/3/17 2.4.4 Q16. Can one carry provenance 2.13.1 Q31. Can one construct out-of- through dataflow alone or also bounds (by more than one) pointer through control flow?........ 21 values by pointer arithmetic (with- 2.5 Pointer provenance and union type punning 23 out undefined behaviour)?..... 31 2.5.1 Q17. Is type punning between inte- 2.13.2 Q32. Can one form pointer values ger and pointer values allowed?.. 23 by pointer addition that overflows 2.5.2 Q18. Does type punning between (without undefined behaviour)?.. 32 integer and pointer values preserve 2.13.3 Q33. Can one assume pointer addi- provenance?............ 23 tion wraps on overflow?...... 32 2.6 Pointer provenance via IO......... 24 2.13.4 Q34. Can one move among 2.6.1 Q19. Can one make a usable pointer the members of a struct using via IO?............... 24 representation-pointer arithmetic 2.7 Q20. Can one make a usable pointer from a and casts?.............. 32 concrete address (of device memory)?... 25 2.13.5 Q35. Can one move between subob- 2.8 Pointer provenance for other allocators... 25 jects of the members of a struct us- 2.9 Stability of pointer values.......... 26 ing pointer arithmetic?....... 33 2.9.1 Q21. Are pointer values stable?.. 26 2.13.6 Q36. Can one implement offsetof 2.10 Pointer Equality Comparison (with == and !=) 26 using the addresses of members of a 2.10.1 Q22. Can one do == comparison be- NULL struct pointer?........ 33 tween pointers to objects of non- 2.14 Casts between pointer types......... 34 compatible types?.......... 26 2.14.1 Q37. Are usable pointers to a struct 2.10.2 Q23. Can one do == comparison be- and to its first member intercon- tween pointers (to objects of com- vertable?.............. 34 patible types) with different prove- nances that are not strictly within 2.14.2 Q38. Are usable pointers to a union their original allocations?...... 28 and to its current member intercon- vertable?.............. 35 2.10.3 Q24. Can one do == comparison of a pointer and (void*)-1?..... 28 2.15 Accesses to related structure and union types 35 2.11 Pointer Relational Comparison (with <, >, 2.15.1 Q39. Given two different structure <=, or >=).................. 28 types sharing a prefix of members 2.11.1 Q25. Can one do relational compar- that have compatible types, can one ison (with <, >, <=, or >=) of two cast a usable pointer to an object of pointers to separately allocated ob- the first to a pointer to the second, jects (of compatible object types)?. 28 that can be used to read and write 2.11.2 Q26. Can one do relational compari- members of that prefix (with strict- son (with <, >, <=, or >=) of a pointer aliasing disabled and without pack- to a structure member and one to a ing variation)?........... 36 sub-member of another member, of 2.15.2 Q40. Can one read from the initial compatible object types?...... 29 part of a union of structures sharing 2.11.3 Q27. Can one do relational compari- a common initial sequence via any son (with <, >, <=, or >=) of pointers union member (if the union type is to two members of a structure that visible)?............... 37 have incompatible types?...... 29 2.15.3 Q41. Is writing to the initial part of 2.12 Null pointers................ 30 a union of structures sharing a com- 2.12.1 Q28. Can one make a null pointer by mon initial sequence allowed via casting from a non-constant integer any union member (if the union type expression?............. 30 is visible)?............. 38 2.12.2 Q29. Can one assume that all null 2.15.4 Q42. Is type punning by writing and pointers have the same representation? 30 reading different union members al- 2.12.3 Q30. Can null pointers be assumed lowed (if the lvalue is syntactically to have all-zero representation bytes? 31 obvious)?.............. 38 2.13 Pointer Arithmetic............. 31 2.16 Pointer lifetime end............. 39 2 2016/3/17 2.16.1 Q43. Can one inspect the value, 3.2.8 Q56. Given multiple bitfields that (e.g. by testing equality with ==) of may be in the same word, can one be a pointer to an object whose life- a well-defined value while another is time has ended (either at a free() an unspecified value?........ 51 or block exit)?........... 40 2.16.2 Q44. Is the dynamic reuse of alloca- 3.2.9 Q57. Are the representation bytes of tion addresses permitted?...... 40 an unspecified value themselves also unspecified values? (not an arbitrary 2.17 Invalid Accesses............... 41 choice of concrete byte values)... 51 2.17.1 Q45. Can accesses via a null pointer be assumed to give runtime errors, 3.2.10 Q58. If one writes some but not rather than give rise to undefined be- all of the representation bytes of an haviour?............... 41 uninitialized value, do the other rep- 2.17.2 Q46. Can reads via invalid pointers resentation bytes still hold unspeci- be assumed to give runtime errors or fied values?............. 52 unspecified values, rather than unde- fined behaviour?.......... 41 3.2.11 Q59. If one writes some but not all of the representation bytes of an uninitialized value, does a read of 3 Abstract Unspecified Values 41 the whole value still give an unspec- 3.1 Trap Representations............ 42 ified value?............. 52 3.1.1 Q47. Can one reasonably assume that no types have trap representa- 3.3 Structure and Union Padding........ 53 tions?................ 42 3.3.1 Q60. Can structure-copy copy 3.1.2 Q48. Does reading an uninitialised padding?.............. 54 object give rise to undefined be- haviour?............... 43 3.3.2 Q61. After an explicit write of a 3.2 Unspecified Values............. 45 padding byte, does that byte hold a 3.2.1 Q49. Can library calls with well-defined value? (not an unspeci- unspecified-value arguments be as- fied value).............. 56 sumed to execute with an arbitrary 3.3.3 Q62. After an explicit write of a choice of a concrete value (not padding byte followed by a write necessarily giving rise to undefined to the whole structure, does the behaviour)?............. 46 padding byte hold a well-defined 3.2.2 Q50. Can control-flow choices value? (not an unspecified value).. 56 based on unspecified values be assumed to make an arbitrary 3.3.4 Q63. After an explicit write of a choice (not giving rise to undefined padding byte followed by a write to behaviour)?............. 46 adjacent members of the structure, 3.2.3 Q51. In the absence of any writes, does the padding byte hold a well- is an unspecified value potentially defined value? (not an unspecified unstable, i.e., can multiple usages of value)...............
Recommended publications
  • Exploring C Semantics and Pointer Provenance
    Exploring C Semantics and Pointer Provenance KAYVAN MEMARIAN, University of Cambridge VICTOR B. F. GOMES, University of Cambridge BROOKS DAVIS, SRI International STEPHEN KELL, University of Cambridge ALEXANDER RICHARDSON, University of Cambridge ROBERT N. M. WATSON, University of Cambridge PETER SEWELL, University of Cambridge The semantics of pointers and memory objects in C has been a vexed question for many years. C values cannot be treated as either purely abstract or purely concrete entities: the language exposes their representations, 67 but compiler optimisations rely on analyses that reason about provenance and initialisation status, not just runtime representations. The ISO WG14 standard leaves much of this unclear, and in some respects differs with de facto standard usage — which itself is difficult to investigate. In this paper we explore the possible source-language semantics for memory objects and pointers, in ISO C and in C as it is used and implemented in practice, focussing especially on pointer provenance. We aim to, as far as possible, reconcile the ISO C standard, mainstream compiler behaviour, and the semantics relied on by the corpus of existing C code. We present two coherent proposals, tracking provenance via integers and not; both address many design questions. We highlight some pros and cons and open questions, and illustrate the discussion with a library of test cases. We make our semantics executable as a test oracle, integrating it with the Cerberus semantics for much of the rest of C, which we have made substantially more complete and robust, and equipped with a web-interface GUI. This allows us to experimentally assess our proposals on those test cases.
    [Show full text]
  • Timur Doumler @Timur Audio
    Type punning in modern C++ version 1.1 Timur Doumler @timur_audio C++ Russia 30 October 2019 Image: ESA/Hubble Type punning in modern C++ 2 How not to do type punning in modern C++ 3 How to write portable code that achieves the same effect as type punning in modern C++ 4 How to write portable code that achieves the same effect as type punning in modern C++ without causing undefined behaviour 5 6 7 � 8 � (�) 9 10 11 12 struct Widget { virtual void doSomething() { printf("Widget"); } }; struct Gizmo { virtual void doSomethingCompletelyDifferent() { printf("Gizmo"); } }; int main() { Gizmo g; Widget* w = (Widget*)&g; w->doSomething(); } Example from Luna @lunasorcery 13 struct Widget { virtual void doSomething() { printf("Widget"); } }; struct Gizmo { virtual void doSomethingCompletelyDifferent() { printf("Gizmo"); } }; int main() { Gizmo g; Widget* w = (Widget*)&g; w->doSomething(); } Example from Luna @lunasorcery 14 15 Don’t use C-style casts. 16 struct Widget { virtual void doSomething() { printf("Widget"); } }; struct Gizmo { virtual void doSomethingCompletelyDifferent() { printf("Gizmo"); } }; int main() { Gizmo g; Widget* w = (Widget*)&g; w->doSomething(); } Example from Luna @lunasorcery 17 18 19 20 float F0 00 80 01 int F0 00 80 01 21 float F0 00 80 01 int F0 00 80 01 float F0 00 80 01 char* std::byte* F0 00 80 01 22 float F0 00 80 01 int F0 00 80 01 float F0 00 80 01 char* std::byte* F0 00 80 01 Widget F0 00 80 01 01 BD 83 E3 float[2] F0 00 80 01 01 BD 83 E3 23 float F0 00 80 01 int F0 00 80 01 float F0 00 80 01 char* std::byte*
    [Show full text]
  • Effective Types: Examples (P1796R0) 2 3 4 PETER SEWELL, University of Cambridge 5 KAYVAN MEMARIAN, University of Cambridge 6 VICTOR B
    1 Effective types: examples (P1796R0) 2 3 4 PETER SEWELL, University of Cambridge 5 KAYVAN MEMARIAN, University of Cambridge 6 VICTOR B. F. GOMES, University of Cambridge 7 JENS GUSTEDT, INRIA 8 HUBERT TONG 9 10 11 This is a collection of examples exploring the semantics that should be allowed for objects 12 and subobjects in allocated regions – especially, where the defined/undefined-behaviour 13 boundary should be, and how that relates to compiler alias analysis. The examples are in 14 C, but much should be similar in C++. We refer to the ISO C notion of effective types, 15 but that turns out to be quite flawed. Some examples at the end (from Hubert Tong) show 16 that existing compiler behaviour is not consistent with type-changing updates. 17 This is an updated version of part of n2294 C Memory Object Model Study Group: 18 Progress Report, 2018-09-16. 19 1 INTRODUCTION 20 21 Paragraphs 6.5p{6,7} of the standard introduce effective types. These were added to 22 C in C99 to permit compilers to do optimisations driven by type-based alias analysis, 23 by ruling out programs involving unannotated aliasing of references to different types 24 (regarding them as having undefined behaviour). However, this is one of the less clear, 25 less well-understood, and more controversial aspects of the standard, as one can see from 1 2 26 various GCC and Linux Kernel mailing list threads , blog postings , and the responses to 3 4 27 Questions 10, 11, and 15 of our survey . See also earlier committee discussion .
    [Show full text]
  • Aliasing Restrictions of C11 Formalized in Coq
    Aliasing restrictions of C11 formalized in Coq Robbert Krebbers Radboud University Nijmegen December 11, 2013 @ CPP, Melbourne, Australia int f(int *p, int *q) { int x = *p; *q = 314; return x; } If p and q alias, the original value n of *p is returned n p q Optimizing x away is unsound: 314 would be returned Alias analysis: to determine whether pointers can alias Aliasing Aliasing: multiple pointers referring to the same object Optimizing x away is unsound: 314 would be returned Alias analysis: to determine whether pointers can alias Aliasing Aliasing: multiple pointers referring to the same object int f(int *p, int *q) { int x = *p; *q = 314; return x; } If p and q alias, the original value n of *p is returned n p q Alias analysis: to determine whether pointers can alias Aliasing Aliasing: multiple pointers referring to the same object int f(int *p, int *q) { int x = *p; *q = 314; return x *p; } If p and q alias, the original value n of *p is returned n p q Optimizing x away is unsound: 314 would be returned Aliasing Aliasing: multiple pointers referring to the same object int f(int *p, int *q) { int x = *p; *q = 314; return x; } If p and q alias, the original value n of *p is returned n p q Optimizing x away is unsound: 314 would be returned Alias analysis: to determine whether pointers can alias It can still be called with aliased pointers: x union { int x; float y; } u; y u.x = 271; return h(&u.x, &u.y); &u.x &u.y C89 allows p and q to be aliased, and thus requires it to return 271 C99/C11 allows type-based alias analysis: I A compiler
    [Show full text]
  • SATE V Ockham Sound Analysis Criteria
    NISTIR 8113 SATE V Ockham Sound Analysis Criteria Paul E. Black Athos Ribeiro This publication is available free of charge from: https://doi.org/10.6028/NIST.IR.8113 NISTIR 8113 SATE V Ockham Sound Analysis Criteria Paul E. Black Software and Systems Division Information Technology Laboratory Athos Ribeiro Department of Computer Science University of Sao˜ Paulo Sao˜ Paulo, SP Brazil This publication is available free of charge from: https://doi.org/10.6028/NIST.IR.8113 March 2016 Including updates as of June 2017 U.S. Department of Commerce Wilbur L. Ross, Jr., Secretary National Institute of Standards and Technology Kent Rochford, Acting NIST Director and Under Secretary of Commerce for Standards and Technology Abstract Static analyzers examine the source or executable code of programs to find problems. Many static analyzers use heuristics or approximations to handle programs up to millions of lines of code. We established the Ockham Sound Analysis Criteria to recognize static analyzers whose findings are always correct. In brief the criteria are (1) the analyzer’s findings are claimed to always be correct, (2) it produces findings for most of a program, and (3) even one incorrect finding disqualifies an analyzer. This document begins by explaining the background and requirements of the Ockham Criteria. In Static Analysis Tool Exposition (SATE) V, only one tool was submitted to be re- viewed. Pascal Cuoq and Florent Kirchner ran the August 2013 development version of Frama-C on pertinent parts of the Juliet 1.2 test suite. We divided the warnings into eight classes, including improper buffer access, NULL pointer dereference, integer overflow, and use of uninitialized variable.
    [Show full text]
  • Half-Precision Floating-Point Formats for Pagerank: Opportunities and Challenges
    Half-Precision Floating-Point Formats for PageRank: Opportunities and Challenges Molahosseini, A. S., & Vandierendonck, H. (2020). Half-Precision Floating-Point Formats for PageRank: Opportunities and Challenges. In 2020 IEEE High Performance Extreme Computing Conference, HPEC 2020 [9286179] (IEEE High Performance Extreme Computing Conference: Proceedings). Institute of Electrical and Electronics Engineers Inc.. https://doi.org/10.1109/HPEC43674.2020.9286179 Published in: 2020 IEEE High Performance Extreme Computing Conference, HPEC 2020 Document Version: Peer reviewed version Queen's University Belfast - Research Portal: Link to publication record in Queen's University Belfast Research Portal Publisher rights Copyright 2020 IEEE. This work is made available online in accordance with the publisher’s policies. Please refer to any applicable terms of use of the publisher. General rights Copyright for the publications made accessible via the Queen's University Belfast Research Portal is retained by the author(s) and / or other copyright owners and it is a condition of accessing these publications that users recognise and abide by the legal requirements associated with these rights. Take down policy The Research Portal is Queen's institutional repository that provides access to Queen's research output. Every effort has been made to ensure that content in the Research Portal does not infringe any person's rights, or applicable UK laws. If you discover content in the Research Portal that you believe breaches copyright or violates any law, please
    [Show full text]
  • A Formal C Memory Model for Separation Logic
    Journal of Automated Reasoning manuscript No. (will be inserted by the editor) A Formal C Memory Model for Separation Logic Robbert Krebbers Received: n/a Abstract The core of a formal semantics of an imperative programming language is a memory model that describes the behavior of operations on the memory. Defining a memory model that matches the description of C in the C11 standard is challenging because C allows both high-level (by means of typed expressions) and low-level (by means of bit manipulation) memory accesses. The C11 standard has restricted the interaction between these two levels to make more effective compiler optimizations possible, at the expense of making the memory model complicated. We describe a formal memory model of the (non-concurrent part of the) C11 stan- dard that incorporates these restrictions, and at the same time describes low-level memory operations. This formal memory model includes a rich permission model to make it usable in separation logic and supports reasoning about program transfor- mations. The memory model and essential properties of it have been fully formalized using the Coq proof assistant. Keywords ISO C11 Standard · C Verification · Memory Models · Separation Logic · Interactive Theorem Proving · Coq 1 Introduction A memory model is the core of a semantics of an imperative programming language. It models the memory states and describes the behavior of memory operations. The main operations described by a C memory model are: – Reading a value at a given address. – Storing a value at a given address. – Allocating a new object to hold a local variable or storage obtained via malloc.
    [Show full text]
  • Low−Level C Topic for CS2263 Alumni −−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−− People Who Have Taken CS2617 Should Instead Read the Full Set of Notes (Cnotes)
    Low−level C Topic for CS2263 Alumni −−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−− People who have taken CS2617 should instead read the full set of notes (cnotes). Note: 2nd ed of textbook was for C−89 (classic "ANSI−C". Third is based on the 2018 revision. There were many changes in 30 years. C−11 and C−99 are also in widespread use. A new version (currently called C−2X) is expected in 2021 or 2022. Change look fairly small (new "decimal floats", if you care.) The Preprocessor −−−−−−−−−−−−−−−− Unlike Java, the C compiler has a "preprocessor" that does textual substitutions and "conditional compilation" before the "real compiler" runs. This was borrowed from assembly languages. Fancy uses of preprocessor are often deprecated, especially since C99. Still commonly used use for defining constants and in doing the C equivalent to Java’s "import". Preprocessor "directives" start with #. No ’;’ at end Macros in the C Preprocessor −−−−−−−−−−−−−−−−−−−−−−−−−−−−− #define FOO 12*2 thereafter, wherever the symbol FOO occurs in your code, it is textually replaced by 12*2 . Think find−and−replace. Macro can have parameters #define BAR(x) 12*x If we have BAR(3*z) in your code, it is textually replaced by 12*3*z #undef BAR will "undefine" BAR. After this, BAR(3*z) remains as is. Perils of Macros −−−−−−−−−−−−−−−−− #define SQUARE(x) ((x)*(x)) used much later with int x = 0; int y = SQUARE(x++); What value for x is expected by a programmer looking only at these lines? What value does x actually have? Making Strings and Concatenating Tokens −−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−− (optional fancy topic) In a macro definition, the # operator puts quote marks around a macro argument.
    [Show full text]
  • Exploring C Semantics and Pointer Provenance
    Exploring C Semantics and Pointer Provenance KAYVAN MEMARIAN, University of Cambridge, UK VICTOR B. F. GOMES, University of Cambridge, UK BROOKS DAVIS, SRI International, USA STEPHEN KELL, University of Cambridge, UK ALEXANDER RICHARDSON, University of Cambridge, UK ROBERT N. M. WATSON, University of Cambridge, UK PETER SEWELL, University of Cambridge, UK The semantics of pointers and memory objects in C has been a vexed question for many years. C values cannot be treated as either purely abstract or purely concrete entities: the language exposes their representations, 67 but compiler optimisations rely on analyses that reason about provenance and initialisation status, not just runtime representations. The ISO WG14 standard leaves much of this unclear, and in some respects differs with de facto standard usage — which itself is difficult to investigate. In this paper we explore the possible source-language semantics for memory objects and pointers, in ISO C and in C as it is used and implemented in practice, focussing especially on pointer provenance. We aim to, as far as possible, reconcile the ISO C standard, mainstream compiler behaviour, and the semantics relied on by the corpus of existing C code. We present two coherent proposals, tracking provenance via integers and not; both address many design questions. We highlight some pros and cons and open questions, and illustrate the discussion with a library of test cases. We make our semantics executable as a test oracle, integrating it with the Cerberus semantics for much of the rest of C, which we have made substantially more complete and robust, and equipped with a web-interface GUI.
    [Show full text]
  • Lenient Execution of C on a JVM How I Learned to Stop Worrying and Execute the Code
    Lenient Execution of C on a JVM How I Learned to Stop Worrying and Execute the Code Manuel Rigger Roland Schatz Johannes Kepler University Linz, Austria Oracle Labs, Austria [email protected] [email protected] Matthias Grimmer Hanspeter M¨ossenb¨ock Oracle Labs, Austria Johannes Kepler University Linz, Austria [email protected] [email protected] ABSTRACT that rely on undefined behavior risk introducing bugs that Most C programs do not strictly conform to the C standard, are hard to find, can result in security vulnerabilities, or and often show undefined behavior, e.g., on signed integer remain as time bombs in the code that explode after compiler overflow. When compiled by non-optimizing compilers, such updates [31, 44, 45]. programs often behave as the programmer intended. However, While bug-finding tools help programmers to find and optimizing compilers may exploit undefined semantics for eliminate undefined behavior in C programs, the majority more aggressive optimizations, thus possibly breaking the of C code will still contain at least some occurrences of non- code. Analysis tools can help to find and fix such issues. Alter- portable code. This includes unspecified and implementation- natively, one could define a C dialect in which clear semantics defined patterns, which do not render the whole program are defined for frequent program patterns whose behavior invalid, but can still cause surprising results. To address would otherwise be undefined. In this paper, we present such this, it has been advocated to come up with a more lenient a dialect, called Lenient C, that specifies semantics for behav- C dialect, that better suits the programmers' needs and ior that the standard left open for interpretation.
    [Show full text]
  • Overload Journal
    A ower Language Nee s Power Tools Smart editor Reliable with full language support refactorings Support for C++03/C++ll, Rename, Extract Function -:(r):- Boost andlibc++,C++ 7 Constant/ Variable, templates and macros. Change8ignature, & more Code generation Profound and navigation code analysis Generate menu, On-the-f y, analysis Find context usages, with Gluick-fixes& dozens 0 Go to Symbol, and more ofsmart checks GET A C++ DEVELOPMENT,:rOOL THAT YOU DESERV ReSharper C++ AppCode CLion Visual Studio Extension IDE for iOS Cross-platform IDE for C•• developers and OS X development for C and C•• developers Start a free 30-day trial jb.gg/cpp-accu Find out more at www.qbssoftware.com QBS SOFTWARE OVERLOAD CONTENTS OVERLOAD 160 December 2020 Overload is a publication of the ACCU ISSN 1354-3172 For details of the ACCU, our publications Editor and activities, visit the ACCU website: Frances Buontempo [email protected] www.accu.org Advisors Ben Curry [email protected] Mikael Kilpeläinen [email protected] 4 Questions on the Form of Software Steve Love Lucian Radu Teodorescu considers whether the [email protected] difficulties in writing software are rooted in the Chris Oldwood essence of development. [email protected] Roger Orr 8 Building g++ from the [email protected] Balog Pal GCC Modules Branch [email protected] Roger Orr demonstrates how to get a compiler that Tor Arve Stangeland supports modules up and running. [email protected] Anthony Williams 10 Consuming the uk-covid19 API [email protected] Donald Hernik demonstrates how to wrangle data Advertising enquiries out of the UK API.
    [Show full text]
  • Anglia Ruskin University a Type-Safe Apparatus
    ANGLIA RUSKIN UNIVERSITY A TYPE-SAFE APPARATUS EXECUTING HIGHER ORDER FUNCTIONS IN CONJUNCTION WITH HARDWARE ERROR TOLERANCE JONATHAN RICHARD ROBERT KIMMITT A thesis in partial fulfilment of the requirements of Anglia Ruskin University for the degree of Doctor of Philosophy This research programme was carried out in collaboration with The University of Cambridge Submitted: October 2015 Acknowledgements This dissertation was self-funded and prepared in part fulfilment of the requirements of the degree of Doctor of Philosophy under the supervision of Dr David Greaves of The University of Cambridge, and Dr George Wilson and Professor Marcian Cirstea at Anglia Ruskin University, without whose help this dissertation would not have been possible. I am grateful to Dr John O’Donnell of The University of Glasgow and Dr Anil Madhavapeddy of The University of Cambridge for their willingness to examine the degree. Dedication Dedicated to my wife Christine Kimmitt i ANGLIA RUSKIN UNIVERSITY ABSTRACT FACULTY OF SCIENCE AND TECHNOLOGY DOCTOR OF PHILOSOPHY A TYPE-SAFE APPARATUS EXECUTING HIGHER ORDER FUNCTIONS IN CONJUNCTION WITH HARDWARE ERROR TOLERANCE JONATHAN RICHARD ROBERT KIMMITT October 2015 The increasing commoditization of computers in modern society has exceeded the pace of associated developments in reliability. Although theoretical computer science has advanced greatly in the last thirty years, many of the best techniques have yet to find their way into embedded computers, and their failure can have a great potential for disrupting society.
    [Show full text]