Skip to content

Commit

Permalink
Describe cv modifiers and checked pointer types.
Browse files Browse the repository at this point in the history
Checked pointer types can be used with cv modifiers.  Add an axplanation of
this to the design.  Add examples of variable declarations that use pointer
types with CV modifiers.

This also includes a few other changes:
- Explain that the idea of span goes way back in computer science.  The
  name is new, but the idea has a long history.  Cite a paper on implementing
  ALGOL 60.
- Improve the description of the new checked pointer types in the introduction.
- Remove some awkward phrasing in the description of bounds-safe interfaces
  in the introduction.
  • Loading branch information
dtarditi committed Apr 22, 2016
1 parent cf05322 commit bf01b97
Show file tree
Hide file tree
Showing 3 changed files with 81 additions and 14 deletions.
61 changes: 56 additions & 5 deletions spec/bounds_safety/core-extensions.tex
Original file line number Diff line number Diff line change
Expand Up @@ -52,14 +52,65 @@ \section{New kinds of pointer types}

The same syntax as C++ template instantiations is used for building
instances of these types because this syntax is well-known and
understood. The parameter to these type constructors must be a type.
understood. The new pointer types are added to the syntax for {\it type specifiers}
\cite[Section 6.7.2]{ISO2011}. The parameters to these type constructors
must be types, which are described syntactically by {\it type names} \cite[Section 6.7.7]{ISO2011}.

The \spanptr\ pointer type is inspired by the proposed \spanptr\ type for
The \spanptr\ pointer type is similar to the proposed \spanptr\ type for
the C++ Standard Library \cite{Macintosh2016}. There is an important
difference between the the types, though. In this design, \spanptr\
difference between the types, though. In this design, \spanptr\
values carry lower and upper bounds. In the proposed C++ design,
\spanptr\ values carry counts of elements. The C++ proposal does not
support decrementing the \spanptr.
support decrementing the \spanptr. While the name \spanptr\ is new,
the idea itself dates back to the early days of computer science.
A \spanptr\ is an instance of a dope vector, which is a data structure
that describes the shape of an array. Dope vectors were used in
implementations of ALGOL60 \cite{Sattley1961}.

Here are examples of declarations using pointer types. These declare variables that
are all pointers to integers:
\begin{verbatim}
int *p;
ptr<int> q;
span<int> r;
array_ptr<int> s;
\end{verbatim}

The new checked pointer types can have \keyword{const} and \keyword{volatile}
modifiers, just like unchecked pointer types. They can be applied to the type
of the object to which the pointers points or to the pointer itself. Here are examples
of pointers to constant integers:
\begin{verbatim}
const int *p;
ptr<const int> q;
span<const int> r;
array_ptr<const int> s;
\end{verbatim}
A pointer to a constant integer cannot be used to modify the value of
the integer.

Here are examples of constant pointers to modifiable integers:
\begin{verbatim}
int x;
int *const p = &x;
const ptr<int> q = &x;
const span<int> r = &x;
const array_ptr<int> s = &x;
\end{verbatim}
In this case, the pointers cannot be modified after they are defined, but
the integer that they point to can be modified. The checked pointer declarations
have simpler syntax than the unchecked pointer declaration, where \keyword{const}
must be placed after the \verb+*+. The checked pointer declarations are all analogous
to \verb+const double y = 5.0;+ declaring a variable \verb+y+ that is \keyword{const}.
In the declaration of \keyword{y}, \keyword{double} specifies a type.
The \keyword{const} keyword is placed before it to declare that
the variable in the declaration is \keyword{const}. In the examples, \ptrint,
\spanptrint, and \arrayptrint\ all specify types too.

The checked pointer types follow the same rules that apply to modifiers for
unchecked pointer types. For example, a variable that is a pointer to a
\keyword{const} value can be assigned a pointer to a non-const value.
The reverse is not allowed.

\section{New kinds of array types}

Expand Down Expand Up @@ -689,7 +740,7 @@ \section{Program scopes for checked pointer types}
...
}
// unchecked at the function level: checked and unchecked pointer types can
// unchecked at the function level: checked and unchecked pointer types can
// occur in argument types, the return type, or the body of the function
unchecked int f(int *p, ptr<int> r)
{
Expand Down
18 changes: 9 additions & 9 deletions spec/bounds_safety/introduction.tex
Original file line number Diff line number Diff line change
Expand Up @@ -62,11 +62,11 @@ \section{Overview}
\item
Introducing different pointer types to capture the different ways in
which pointers are used. The unchecked C pointer type \texttt{*} is kept
and three new pointer types are added: one for pointers that are never
used in pointer arithmetic (\ptr), one for \emph{array pointer
types} (\arrayptr) that are involved in pointer arithmetic,
and one for pointer types that carry their dynamic bounds with them
(\spanptr ).
and three new {\it checked} pointer types are added: one for pointers that
are never used pointer arithmetic and do not need bounds checking (\ptr) ,
one for \emph{array pointer types} that are involved in pointer
arithmetic and need bounds checking (\arrayptr) , and one for pointer types
that carry their bounds with them dynamically (\spanptr).
\item
For array pointer types (\arrayptr), in keeping with the low-level
nature of C, bounds checking is placed under programmer control.
Expand Down Expand Up @@ -99,8 +99,8 @@ \section{Overview}
interoperation between checked code and unchecked code. A bounds-safe
interface describes the checked interface to unchecked code by declaring
bounds for unchecked pointers in function signatures and data structures.
Because it describes a boundary, it has to be ``checked'' and ``unchecked''
at the same time, depending on what kind of code is using it. The
It describes a boundary that is ``checked'' or ``unchecked''
depending on what kind of code is using it. The
interface is trusted in checked code (code that uses only checked pointer types).
Proper usage is enforced via checking at compile time and runtime. For
code that uses only unchecked pointer types, the interface is descriptive and
Expand Down Expand Up @@ -472,7 +472,7 @@ \section{Acknowledgements}

This design has benefited from many discussions with Weidong Cui, Gabriel Dos Reis,
Chris Hawblitzel, Galen Hunt, Shuvendu Lahiri, and Reuben Olinsky. The design has
benefited also from feedback from Michael Hicks, Greg Morrisett, Andrew Ruef, and Jonghyun
Park. We thank them for their contributions to the design.
benefited also from feedback from Michael Hicks, Greg Morrisett, Jonghyun
Park, and Andrew Ruef. We thank them for their contributions to the design.


16 changes: 16 additions & 0 deletions spec/bounds_safety/sources.bib
Original file line number Diff line number Diff line change
Expand Up @@ -174,3 +174,19 @@ @Book{Ritchie1988
publisher="Prentice Hall",
address="Englewood Cliffs, New Jersey, USA"
}

@article{Sattley1961,
author = "Kirk Sattley",
title = {Allocation of Storage for Arrays in {ALGOL} 60},
journal = {Communications of the ACM},
volume = {4},
number = {1},
month = jan,
year = {1961},
issn = {0001-0782},
pages = {60--65},
url = {http://doi.acm.org/10.1145/366062.366088},
doi = {10.1145/366062.366088},
publisher = {ACM},
address = {New York, NY, USA},
}

0 comments on commit bf01b97

Please sign in to comment.